1002 写出这个数 (20)(20 分)
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10^100^。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
1.下面这个程序是的第一种解法: 有点小缺点,只能满足输入的数字不能超过10的18次方.题目要求n小于10^100,这个是自己尝试了其他的办法.
#include <stdio.h>
int main(){
long long n;
long long sum=0LL;
char pinyin[][10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int a[100];
int t=0;
//输出10的18次方以内没问题哦.
scanf("%lld",&n);
//累加求n的各个位数之和
while(n!=0){
sum=sum+n%10;
n=n/10;
}
//看看sum是几位数,用t记录位数,并把每个数字存在数组a中,
while(sum!=0){
a[t]=sum%10;//倒序存储,因为是从个位存的
sum=sum/10;
t++;//记录位数
}
//嵌套数组映射,将数字转化成对应的拼音
for(int i=t;i>0;i--){
printf("%s ",pinyin[a[i-1]]);
}
return 0;
}
2.gets()方法在PAT的OJ上不能通过,最后采用C++的cin<<
#include<iostream>
#include <stdio.h>
#include <string.h>
using namespace std;
int main(){
char pinyin[][10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
char c[100];
//gets(c);
cin>>c;
int a[10]={0};
int sum=0;
int t=0;
for(int i=0;i<strlen(c);i++){
sum=sum+c[i]-'0';
}
while(sum!=0){
a[t]=sum%10;
sum=sum/10;
t++;
}
printf("%s ",pinyin[a[t-1]]);
for(int j=t;j>1;j--){
printf(" %s",pinyin[a[j-2]]);
}
return 0;
}
3.第三方法代码能少点:
#include<cstdio>
int main()
{
int sum=0;
char ch,s[4]; //ch作为临时变量保存输入的每一个字符,s保存sum的每一个数字
char b[10][5]={"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"};
while ((ch = getchar()) != '\n') //如果一直输入字符,不按回车的话
sum += (ch - '0');
sprintf(s, "%d", sum); // sprintf(char *buffer, const char *format,[ argument])将任意类型数据按某种格式转换成字符串
for (int i = 0; s[i] != 0; i++){
if (i > 0)
printf(" ");
printf("%s", b[s[i]-'0']);
}
return 0;
}
summary:
整型和字符型可以通过ANSⅡ的值来互换, 0的ANSⅡ的值为 48.
字符的'0','1','2','3','4'等等,可以通过给它们减去 48或者'0'就可以得到他们的整型值了.
'9'-48=9;
取个位的方法: 数字%10;就可以得到