5-2. 念数字(15)

5-2. 念数字(15)

时间限制
400 ms
内存限制
32000 kB
代码长度限制
8000 B
判题程序
Standard
作者
翁恺(浙江大学)

输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出“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
#include <stdio.h>
int main()
{	int x;
	int cnt,mask;
	cnt=0;
	mask=1;
	int d;
	int t;
	//printf("%d\n",12345%1000000);
	scanf("%d",&x);
	if(x<0){//判断是否为负数,并将负数转换为正数 
		x=-x;
		printf("fu ");
	}

	t=x;//保持传入的x值不被消耗掉 
	while(t>9)
	{
		t/=10;//依次去掉右边一位,循环次数加一就是有几位数 
		//所以cut初始值设为1 
		cnt++;//其实没有用到计数,利用循环输出了每一个数字 
		mask*=10;//同时计算出mask值,就是每次模数,除数 
		//printf("x=%d,cnt=%d,mask=%d\n",t,cnt,mask);			
	}
	while(mask>0)
		{
		d=x/mask;//ex:12345/10000=1,12345%10000=2345,10000/10=1000 
		//printf("%d",d);
		switch(d)//得到的每一位用switch case判断输出 
		{
		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:
       		printf(" ");
       	}
       	if(mask>9)//去除末尾最后的空格
		   //只有不是最后一位的时候才输出空格 
       	{
       		printf(" ");
       	}
		x%=mask;
		mask/=10;
		}

	return 0;
} 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值