PAT (Advanced Level) 1023. Have Fun with Numbers (20) 字符串翻倍,哈希
2015-07-22 16:41
537 查看
Notice that the number 123456789 is a 9-digit number consisting exactly the numbers from 1 to 9, with no duplication. Double it we will obtain 246913578, which happens to be another 9-digit number consisting exactly the numbers from 1 to 9, only in a different
permutation. Check to see the result if we double it again!
Now you are suppose to check if there are more numbers with this property. That is, double a given number with k digits, you are to tell if the resulting number consists of only a permutation of the digits in the original number.
Input Specification:
Each input file contains one test case. Each case contains one positive integer with no more than 20 digits.
Output Specification:
For each test case, first print in a line "Yes" if doubling the input number gives a number that consists of only a permutation of the digits in the original number, or "No" if not. Then in the next line, print the doubled number.
Sample Input:
Sample Output:
[/code]
permutation. Check to see the result if we double it again!
Now you are suppose to check if there are more numbers with this property. That is, double a given number with k digits, you are to tell if the resulting number consists of only a permutation of the digits in the original number.
Input Specification:
Each input file contains one test case. Each case contains one positive integer with no more than 20 digits.
Output Specification:
For each test case, first print in a line "Yes" if doubling the input number gives a number that consists of only a permutation of the digits in the original number, or "No" if not. Then in the next line, print the doubled number.
Sample Input:
1234567899
Sample Output:
Yes 2469135798
字符串处理。使用一个数组a[10]作哈希表判断是否匹配。
/*2015.7.22cyq*/ #include <iostream> #include <vector> #include <string> using namespace std; string doubleString(const string &s1){ string s2(s1); int carry=0; int tmp; for(auto it=s2.rbegin();it!=s2.rend();it++){ tmp=(*it-'0')*2+carry; carry=tmp/10; *it=tmp%10+'0'; } if(carry>0) s2.insert(s2.begin(),1,carry+'0'); return s2; } int main(){ string s1; cin>>s1; string s2=doubleString(s1); vector<int> a(10,0); int n1=s1.size(); int n2=s2.size(); if(n2>n1) cout<<"No"<<endl; else{ bool match=true; for(int i=0;i<n1;i++){ a[s1[i]-'0']++; } for(int i=0;i<n2;i++){ if(--a[s2[i]-'0']<0){ match=false; break; } } if(match) cout<<"Yes"<<endl; else cout<<"No"<<endl; } cout<<s2<<endl; return 0; }
[/code]
相关文章推荐
- Action中通过Ajax返回特定值的方法(而不是整个页面)
- XAMPP Error: Apache shutdown unexpectedly
- PHPStorm 配置XDebug 调试PHP代码 详细教程
- HDU5289 Assignment
- Android的NDK开发(6)——如何定位Android NDK开发中遇到的错误
- Android的NDK开发(6)——如何定位Android NDK开发中遇到的错误
- IOS - 修改头像
- SVN Commit Failed Transaction is out of date问题
- C#基础回顾:正则表达式
- JEECMS源代码基本结构及相关技术简介
- 使用GPIO模拟I2C总线进行通信
- static、final修饰符、内部类
- POJ 1850 Code(组合数学)
- 获取系统时间,判断是时间段(早上,上午,中午,下午,晚上)
- Mysql连接数据库封装类
- 【GPU编解码】GPU硬解码---DXVA
- Day04笔记
- a+b 5
- UVA 12563 Jin Ge Jin Que Hao
- Android APP崩溃上传日志到服务器并且重启!