正の整数Aの"Dの*のA ** 部分(整数として)"として定義されているすべての* D ** *新しい組成物は整数* P Aを。例えば:考える A = 3862767、 D A = 6、次に* P **の"セクション6" A * 66、ので、Aは、 2個の6を有します。
今与えられたA、D Aは、 B 、 D Bは、計算するためのプログラム書き込みP A + P Bを。
入力フォーマット:
所与の入力ラインに順次A、D A 、 B 、 D B 0 <スペースで区切られた、A、B <1010。
出力フォーマット:
出力線P A + P Bの値。
サンプル入力1:
3862767 6 13530293 3
出力サンプル1:
399
サンプル入力2:
3862767 1 13530293 8
出力サンプル2:
0
考え
- 実際に再びトラバース番号の数のように、文字列の問題に対処
- 使用
stringstream
改宗を書いたが〜自分自身を救うために、
コード
#include<bits/stdc++.h>
using namespace std;
int get_num(string s, int x)
{
string ans = "";
for(int i=0;i<s.size();i++)
{
int num = s[i] - '0';
if(num == x)
ans += (char)(x + '0');
}
stringstream ss;
int value = 0;
ss << ans;
ss >> value;
return value;
}
int main()
{
string a, b;
int da, db;
cin >> a >> da >> b >> db;
cout << get_num(a,da) + get_num(b,db);
return 0;
}
引用文
https://pintia.cn/problem-sets/994805260223102976/problems/994805306310115328