p1002写出这个数
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789 |
---|
yi san wu |
#include <iostream>
#include <string>
using namespace std;
int main()
{
string str;
unsigned int sum=0;
int count[10000],i=0;
string shu[10]= {"lin","yi","er","san","si","wu","liu","qi","ba","jiu"};
cin>> str;
for(unsigned int j = 0; j < str.size(); j++)
sum+= (str[j]-'0'); //计算出str各位数相加结果sum
while(sum != 0)
{
count[i]=sum%10;
sum/=10;
i++;
} //把sum倒序放入count中
for(; i > 0; i--)
{
cout << shu[count[i - 1]]; //一定注意是i-1,因为count也是从0开始计数
if(i != 1){ //i不等于1,即只要不是最后一个,都输出空格
cout << " ";
} //因为是倒序 所以从尾部向前输出各位数 再利用shu数组输出拼音
return 0;
}
要点总结:
1.这个题的一个难点就是数字很大,unsigned long都不够10的100次方,所以必须要用string来存储。
2.一定要注意输出的最后一个拼音后面不能带有空格!否则会RE,我因为之前找死都没找到这个问题。
3.(程序中用到的str[j]-'0’的意思:假如str[0]存放的数据类型是字符‘1’,那么减去‘0’就得到一个整形数字1,而不是字符型‘1’,可以查看C程序设计的最后面的“常用字符与ASCLL代码对照表”。字符‘0’的ASCLL值是48,而字符‘1’是49,所以str[0]-'0’相当于49-48=1)
ps:我这段代码不是满分