7-25 念数字
作者 翁恺
单位 浙江大学
输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出fu
字。十个数字对应的拼音如下:
0: ling
1: yi
2: er
3: san
4: si
5: wu
6: liu
7: qi
8: ba
9: jiu
输入格式:
输入在一行中给出一个整数,如:1234
。
提示:整数包括负数、零和正数。
输出格式:
在一行中输出这个整数对应的拼音,每个数字的拼音之间用空格分开,行末没有最后的空格。如yi er san si
。
输入样例:
-600
输出样例:
fu liu ling ling
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
解答
#include <stdio.h>
int main(){
int num;
scanf("%d",&num);
if(num<0){
printf("fu ");
num=-num;
} else if(num==0){
printf("ling");
return 0;
} // 先讨论特殊情况
int i,k;
char save[100]; //用数组形式的字符串,可读写
for(k=0;num!=0;k++){
save[k]=num%10;
num=num/10; // 写入数组
}
for(i=k-1;i>=0;i--){ // 需要逆序输出
if(save[i]==1){
printf("yi");
} else if(save[i]==2){
printf("er");
}else if(save[i]==3){
printf("san");
}else if(save[i]==4){
printf("si");
}else if(save[i]==5){
printf("wu");
}else if(save[i]==6){
printf("liu");
}else if(save[i]==7){
printf("qi");
}else if(save[i]==8){
printf("ba");
}else if(save[i]==9){
printf("jiu");
}else if(save[i]==0){
printf("ling");
}
if(i!=0){
printf(" "); // 注意审题,输出要求最后没有空格
}
}
return 0;
}
方法
1、字符串:可读写用char x[],只读可以用char*x
2、数字逆序:只需声明两个变量就行了,如本题中k,i
总结
本题主要考察字符串。要有数字倒序的思路,另外一些细节,比如特殊情况,空格都需要注意