PAT乙级 1002 写出这个数---详解

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

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

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

输入样例:
1234567890987654321123456789
输出样例:
yi san wu

题目分析:
注意点:
1.n的范围超过了整数,所以可以使用字符数组存储测试用例。另外,对于牵扯处理"每一位或某些位"的题目,都可以选择使用字符数组存储测试用例。
2.因为使用字符串存储,则在加和时需要进行字符-数字转化:例‘1’-‘0’=1;
(拓展:字符串-数字转化可以用num=atoi(str)转化,其中num为转化后的数值,str为待转化的字符串)
3.数组存储时高阶位存储数字的低位,所以输出时采用逆向输出
提示:sz3[sz2[j-1]];这种查找方法建议掌握,十分高效,之后的题目中会经常遇到
4.控制空格常见方法:
第一种:前导空格,即先输入一个数据不加空格,之后每个数据都在前面加一个空格。
第二种:预先记录输出数据的数量,然后在输出时控制,即每输出一个数据,输出一个空格,最后一个数据之后不输出空格(较常用)

#include<stdio.h>
#define N 110
char sz3[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};//数字对应读音
int main()
{
	int i,j=0,sum=0,sz2[4]={0};//sum为最终加和,sz2为加和值的每一位数字
	char sz[N];//测试用例
	
	scanf("%s",sz);
	for(i=0;sz[i]!='\0';i++)
		sum+=sz[i]-'0';//字符-数字转化
	while(sum!=0)
	{
		sz2[j++]=sum%10;//存储每一位上的数值
		sum/=10;
	}
	printf("%s",sz3[sz2[j-1]]);//输出最高位
	for(i=j-2;i>=0;i--)//逆向输出
	    printf(" %s",sz3[sz2[i]]);//这里使用了前导空格的方法控制空格
	printf("\n");		    
    return 0;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值