PTA1002 写出这个数
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10的100次方
。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
作者
CHEN, Yue
单位
浙江大学
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
斜体样式我原来没考虑到数字太大的问题,所以我就这样写的:(但我的问题就只有这一个,有点长)
#include<stdio.h> #include<math.h> int main(){ long long n; scanf("%lld",&n); int sum=0; // printf("%lld\n",n); while(n){ //求各位之和 sum+=(n%10); n/=10; } int y; y=sum; //把sum存入y; // printf("sum=%d\n",sum); int len=0; //计和有多少位 //log10(sum)+1也行 while(sum){ sum/=10; len++; } // printf("len=%d\n",len); sum=y; //恢复sum的值 // printf("sum=%d\n",sum); int num[3]; //和最多是900,三位数 int i,j; for(i=0;i<len;i++){ //从个位开始存在数组num[]中 sum/=pow(10,i); num[i]=sum%10; } // for(i=0;i<len;i++){ // printf("%d,,",num[i]); // } int temp ,m; //逆序存数组 num[] m=(len-1)/2; for(i=0;i<=m;i++) { j=len-1-i; temp=num[i]; num[i]=num[j]; num[j]=temp; } // for(i=0;i<len;i++){ // printf("%d..",num[i]); // } for(i=0;i<len;i++){ //念数字 if(i==0){ //第一位格式为x ,以后的是空格x switch(num[i]){ //这样就符合格式了 case 0:printf("ling");break; case 1:printf("yi");break; case 2: printf ("er");break; case 3: printf ("san");break; case 4: printf ("si");break; case 5: printf ("wu");break; case 6: printf ("liu");break; case 7: printf ("qi");break; case 8: printf("ba");break; case 9: printf("jiu");break; } } else{ switch(num[i]){ case 0:printf(" ling");break; case 1:printf(" yi");break; case 2: printf (" er");break; case 3: printf (" san");break; case 4: printf (" si");break; case 5: printf (" wu ");break; case 6: printf (" liu");break; case 7: printf (" qi ");break; case 8: printf(" ba");break; case 9: printf(" jiu");break; } } } printf("\n"); for(i=0;i<len;i++){ //念数字 switch(num[i]){ case 0:printf("ling");break; case 1:printf("yi");break; case 2: printf ("er");break; case 3: printf ("san");break; case 4: printf ("si");break; case 5: printf ("wu");break; case 6: printf ("liu");break; case 7: printf ("qi");break; case 8: printf("ba");break; case 9: printf("jiu");break; } if(i!=len){ printf(" "); } } }
下面是我搜大神写的:
#include <stdio.h> int ctoi(char num){//把一个char型数字,转化成int return num - '0'; } int main(){ int store[3];//store各位保存一个count的位数,因为count之和最大不过900,所以三位就够用 char num[100];//为了能够存下10^100,这么大个数。而C语言中整型数据类型没有能存得下的 scanf("%s",&num); int i = 0; int count = 0; while(num[i] != '\0'){ count += ctoi(num[i]); //变为数字 求和 i ++; } for(i = 0;count;i ++){ //各位 store[i] = count % 10; count /= 10; } i--; //i=i-1;初始值 for(;i >= 0;i --){ switch(store[i]){ case 0: printf("ling");break; case 1: printf("yi");break; case 2: printf("er");break; case 3: printf("san");break; case 4: printf("si");break; case 5: printf("wu");break; case 6: printf("liu");break; case 7: printf("qi");break; case 8: printf("ba");break; case 9: printf("jiu");break; } // if (store[i] != '\0')//此处尤为精妙,也是我没有意料到的 // printf(" "); // else{ // printf("\n"); //} if(i!=0){ printf(" ");} } }