zoukankan      html  css  js  c++  java
  • 【算法笔记】B1016 部分A+B

    1016 部分A+B (15 分)

    正整数 A 的“DA​​(为 1 位整数)部分”定义为由 A 中所有 DA​​ 组成的新整数 PA​​。例如:给定 A=3862767,DA​​=6,则 A 的“6 部分”PA​​ 是 66,因为 A 中有 2 个 6。

    现给定 A、DA​​B、DB​​,请编写程序计算 PA​​+PB​​。

    输入格式:

    输入在一行中依次给出 A、DA​​B、DB​​,中间以空格分隔,其中 0<A,B<1010​​。

    输出格式:

    在一行中输出 PA​​+PB​​ 的值。

    输入样例 1:

    3862767 6 13530293 3
    

    输出样例 1:

    399
    

    输入样例 2:

    3862767 1 13530293 8
    

    输出样例 2:

    0

    思路:

    枚举PA的每一位,如果与DA相同,就执行 PA = PA * 10 +DA。PB同理可得,最后输出PA+PB

    为了简化代码定义一个函数getP()。注意题目的范围是1010,所以用long long定义A和B。

    CODE:

    #include<iostream>
    using namespace std;
    
    long long getP(long long a,int da){
        int i = 0, pa = 0;
        long long t = a;
        while(t){
            if(t % 10 == da){
                pa = pa * 10 + da; 
            }
            t /= 10;
        }
        return pa;
    }
    
    int main(){
        long long a, b;
        int da, db;
        cin>> a >> da >> b >> db;
        cout<< getP(a, da) + getP(b, db);
        return 0;
    }
  • 相关阅读:
    java基础(一)
    java概述
    七大查找十大排序之二排序
    bat批处理脚本语言(一)
    photoshop安装与破解
    office——excel常用函数
    arcgis engine开发环境搭建
    七大查找十大排序算法(一)
    华为路由交换常用命令
    cisco路由交换常用命令
  • 原文地址:https://www.cnblogs.com/chunlinn/p/10521214.html
Copyright © 2011-2022 走看看