L1-007. 念数字
输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出“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
这看起来是一题不算很难的题,但是要注意细节,提交下去的时候一直都是不正确的,所以也不知道为什么,然后看了一下输出条件才知道自己是错在哪了,我们仔细看输出条件才会知道原来输出最后是不能输出空格的,所以说细节是很重要的,还有就是学会写函数,每个函数执行不同的功能,这样代码看起来就简单多了。而且在修改的时候也会变得很容易多了。还有就是发现在定义数组的时候里面【】老是打错成其他的字母,这也是非常容易错的一部分。
思路:我的思路就是先把输入的数反过来;因为要最先输出的是头头的那个数,所以把数反过来之后,求余就这样先把第一个数输出出来。但是又会有1200,这样的情况出现,所以我又设了个k把零先存起来,然后后面通过循环把零也输出出来。
#include<stdio.h>
void fun(int n)//定义一个函数专门把数字转成拼音输出
{
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;
}
}
int main()
{
int n;
scanf("%d",&n);
if(n<0){//考虑到为负数的情况下,把负数变为正数,并且先输出一个fu
printf("fu ");
n=-n;}
int k=0;
while(n%10==0){//后面如果是零的情况下先把零存起来,到后面输出
k++;
n=n/10;
}
int n2=0;//把n反过来存入n2中
while(n>0)
{
n2=n2*10;
n2=n2+n%10;
n=n/10;
}
while(n2>9)//防止后面出现空格 ,只有n2大于9的情况输出 空格
{
n=n2%10;
fun(n);
printf(" ");
n2=n2/10;
}
fun(n2);//输出最后的一个数,不带空格
int i;
for(i=0;i<k;i++)//把0的情况也输出出来
{
printf(" ");
fun(0);
}
return 0;
}
还有我同学的代码,个人觉得同学写的代码比较简单易懂,不像我换来换去。不过我觉得可以改进的地方就是可以增加一个像我一样的函数,可以让自己的1代码更简单易懂一些。
#include<stdio.h>
int main()
{
int n,i;
int a,b,c=1,d;
scanf("%d",&a);
if(a<0)
{
printf("fu ");
a=-a;
}
b=a;
while(b>9){
b=b/10;
c=c*10;
}
while(c>0){
d=a/c;
switch(d){
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(c>9)
printf(" ");
a=a%c;
c=c/10;
}
return 0;
}