1016 部分A+B (15分)
标签:set ems str com bsp ace text return color
正整数 A 的“D?A??(为 1 位整数)部分”定义为由 A 中所有 D?A?? 组成的新整数 P?A??。例如:给定 A=3862767,D?A??=6,则 A 的“6 部分”P?A?? 是 66,因为 A 中有 2 个 6。
现给定 A、D?A??、B、D?B??,请编写程序计算 P?A??+P?B??。
输入在一行中依次给出 A、D?A??、B、D?B??,中间以空格分隔,其中 0<A,B<10?10??。
在一行中输出 P?A??+P?B?? 的值。
3862767 6 13530293 3
399
3862767 1 13530293 8
0
题目很简单,直接上代码
1 #include<iostream> 2 #include<string> 3 using namespace std; 4 int main () 5 { 6 string A,B; 7 short DA,DB; 8 long PA=0,PB=0,k1=1,k2=1; 9 cin>>A>>DA>>B>>DB; 10 for(unsigned int i=0,j=0;i<A.length()||j<B.length();i++,j++) 11 { 12 if(i<A.length()&&A[i]-‘0‘==DA) 13 { 14 PA+=DA*k1; 15 k1*=10; 16 } 17 if(j<B.length()&&B[i]-‘0‘==DB) 18 { 19 PB+=DB*k2; 20 k2*=10; 21 } 22 } 23 cout<<PA+PB<<endl; 24 return 0; 25 }
ac了
标签:set ems str com bsp ace text return color
原文地址:https://www.cnblogs.com/buanxu/p/12813094.html