1002 写出这个数 (20 分)
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
原本我是这样的,错误
int n;
cin>>n;
int k=0;
while(n){
k=k+n%10;
n=n/10;
}
后来想到数很大,我用了longlong,还是错,部分正确
long long n;
scanf("%lld",&n);
int k=0;
while(n){
k=k+n%10;
n=n/10;
}
我输出看了一下,n/10,这步一做,数字少了一半
然后我就百度了
全部正确
int n;
int k = 0;
while ((n = getchar()) != '\n')
k = k + n-'0';
这种方式也正确
char s[105];
scanf("%s", s);
int k = 0;
for (int i = 0; s[i] != '\0'; i++)
k += s[i] - '0';
附全部代码:
#include<iostream>
#include<string>
using namespace std;
string read(int i){
switch (i)
{
case 0:
return "ling";
case 1:
return "yi";
case 2:
return "er";
case 3:
return "san";
case 4:
return "si";
case 5:
return "wu";
case 6:
return "liu";
case 7:
return "qi";
case 8:
return "ba";
case 9:
return "jiu";
default:
break;
}
return 0;
}
int main(){
/*int n;
int k = 0;
while ((n = getchar()) != '\n')
k = k + n-'0';*/
char s[105];
scanf("%s", s);
int k = 0;
for (int i = 0; s[i] != '\0'; i++)
k += s[i] - '0';
int i = -1;
int a[100000];
while (k > 0){
a[++i] = k % 10;
k = k / 10;
}
for (int j = i; j > 0; j--){
cout << read(a[j]) << " ";
}
cout << read(a[0]);
system("pause");
return 0;
}