考试算是告一段落了,好久没有写代码了。。。看着博客都觉得很陌生,从头开始吧
加油!为了offer拼了
ps:太水的题目我就不放了。
1002. 写出这个数 (20)
时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
CHEN, Yue
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:1234567890987654321123456789输出样例:
yi san wu
然后利用对应字符和'0'的差值来计算他的真值
然后就是加起来,每一位从头至尾单独处理就好了~
细节上来说肯定是要先计算数字长度,然后利用除10^长度 和 对10^长度取模来解决了
代码如下
#include<stdio.h>
#include<string.h>
#include<math.h>
int main(){
char ch[101];
int num;
scanf("%s",ch);
int i,n,len1,len2,temp,sum=0;//n为最终和的每一位,len1为输入长,len2为总和长度
len1=strlen(ch);
for(i=0;i<len1;i++){//求和
sum+=ch[i]-'0';
}
temp=sum;
for(len2=0;temp>0;len2++)temp/=10;
for(temp=sum;len2>0;len2--){//每一位单独处理
n=temp/(int)pow(10,len2-1);
temp=temp%(int)pow(10,len2-1);
switch(n){
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(len2!=1)
printf(" ");
}
return 0;
}