写出这个数

读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

输入格式:

每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。

输出格式:

在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。

样例:">样例:">样例:">样例:">样例:">样例:">样例:">样例:">输入样例:

1234567890987654321123456789

输出样例:

yi san wu

解题思想:本题需要注意一点,输入样例不可以直接设置一个int变量来存储,数据太大了会溢出的,存放不下,应该用一个数组来存放输入的数据。然后设置一个拼音输出函数,很显然是使用switch语句,不同的数字对应不同的拼音,不要把这一步放在主函数里面,否则代码会很乱,不方便阅读。此时我们已经把数据存在数组里面了,然后只需要把数组里面的值全部加起来就和就行了,再把这个和的每位数字进行分解,存放在另一个数组里面。因为题目输出的是从百位,十位,个位依次输出的,所以先放在数组里面进行调换位置,不能直接模再除,这样顺序是反着的。最后题目的要求,行中最后一个拼音数字后没有空格,这个只需要做点小手段就好了,不是本题的难点所在,解析大概就是这样,其他请看代码部分。


#include<stdio.h>
#include<string.h>
void prif(int n)
{
	switch(n)
	{
	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;
	case 0:
		printf("ling");
		break;
	}
}

int main()
{
	int n,ret;
	int sum=0;
	char num[100];
	int a[10],i=0,j;
	scanf("%s",num);//num[]存放输入数据
	n=strlen(num);//求出输入数据的长度
	j=n;
	while(j>0)
	{
		//至于这里为什么要-'0',我查看了一下数组中存放的数据
		//刚好每位数多了0的acii值
		sum+=(num[j-1]-'0');
		j--;
	}
	ret=sum;
	//把求出的和的每位数字分解开,放入数组a中
	while(ret!=0)
	{
		a[i]=ret%10;
		ret/=10;
		i++;
	}
	//由于后面的格式要求,所以先把第一个输出来,再后面按照空格输出
	//其他的
	prif(a[i-1]);
	i--;
	for(i-1;i>0;i--)
	{
		printf(" ");
		prif(a[i-1]);
	}
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

火花怪怪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值