题134.pat甲级练习-1023 Have Fun with Numbers (20 分)
一、题目
二、题解
看到题目说输入的数位数最多为20你就可以断定用普通的乘2得到结果进行比对肯定不行,因为数太大了,这时候我们自然就会想到用模拟竖式乘法来处理它。
#include <bits/stdc++.h>
using namespace std;
map<int,int> m;
int main()
{
string num;
cin>>num;
for(int i=0;i<num.length();i++)
{
m[num[i]-'0']++;
}
vector<int> temp(num.length()+1);
stack<int> res;
int flag=1;
temp[temp.size()-1]=0;
int i;
for(i=num.length()-1;i>=0;i--)
{
int res0=(num[i]-'0')*2;
res.push(res0%10+temp[i+1]);
if(m.find(res.top())==m.end()||m[res.top()]==0)
{
flag=0;
}
else
{
m[res.top()]--;
}
temp[i]=res0/10;
}
if(temp[i+1])
{
res.push(temp[i+1]);
}
if(!flag||res.size()!=num.length())
{
cout<<"No"<<endl;
}
else
{
cout<<"Yes"<<endl;
}
while(!res.empty())
{
cout<<res.top();
res.pop();
}
}
tip: 对于代码中res0%10+temp[i+1]的解释:
|