分数 15
作者 翁恺
单位 浙江大学
输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出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
表面上简单,但上手之后发现小步骤非常多!
- 首先要分0+-三种情况,这里应该把负数判断放在正数前面,因为后面需要一样的流程
- 然后读出有几位,存放在一个数组里(之前做过读整数每一位的题,在这里只是一小步)
- 遍历数组switch case每一个数对应的拼音输出
- 最后记得\b退位末尾的空格转为\n换行
- 结束!
// 读入num
// 0直接输出
// 负数:输出fu,然后*-1再按正数来
// 正数:首先计算出位数//for(i=0;num/10!=0;i++)好像不好,还是用do while比较ok
// 定义数组a[i]
// 从i-1位开始倒着读数字num%10
// for(;i>=0;i--){
// a[i-1]=num%10;
// num%=10;
// }
// 遍历数组switch case
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char const *argv[])
{
int firstnum; //储存读数
scanf("%d", &firstnum);
if (firstnum == 0)
{
printf("ling \n");
}
else if (firstnum < 0)
{
printf("fu ");
firstnum *= -1;
}
if (firstnum > 0)//这里是重新开了一种有非零数字的情况
{
int i = 0;
int num = firstnum;
do
{
num /= 10;
i++;
} while (num != 0); //计算位数
int a[i];
int firsti = i; //储存位数
num = firstnum;
for (; i >= 0; i--)
{
a[i - 1] = num % 10;
num /= 10;
} //记录每一位的数字
i = firsti;
int j;
for (j = 0; j < i; j++)
{
switch (a[j])
{
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;
default:
break;
}
}
}//终于开始读出每一位的数字啦
printf("\b\n");//\b是退位符,为了把末尾的空格消去,然后用\n来代替
system("pause");
return 0;
}
或许有简便的办法,过段时间再回来看看吧~