菜鸟PAT训练之旅-2

1002. 写出这个数 (20)

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
CHEN, Yue

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

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

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

输入样例:
1234567890987654321123456789
输出样例:
yi san wu
题目解析:刚开始我想到的直接将数据存到int形当中,再不断除以10取每一位数,后来发现int形的长度太小没有足够空间存储数据。随后使用字符数组获取数据,直接可以使用scanf("%s",&arry)就能直接获取数据,不必要再用循环单个一位一位获取,还要考虑循环次数和循环的结尾。用循环计算出结果(遇到\0停止循环),注意将最后的条件拼音的顺序别弄饭了,空格数要是N-1.
代码找到网上的进行了修改:
#include <stdio.h>
#include <stdlib.h>
#define N 100
#define M 5
int main()
{
char numChar[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};//将10个汉语拼音先存到数组当中,需要时进行使用
char array[N];//用于存放数据的char形数组,千万不能说是int形
int sum=0,i=0,j;
int index[M];//存放数据和每一位的数组
for(i=0;i<M;i++)//先将数组初始化,便于识别数据和数据的空间
index[i]=-1;
scanf("%s",array);//存入数据
i=0;
while(array[i]!='\0')//求和
{
sum+=array[i]-'0';//将char形转换成int形
i++;
}
j=0;
while(sum>0){//将和的每一位求出,并按从低位到高位的顺序排列
index[j]=sum%10;
sum=sum/10;
j++;
}
for(i=M-1;i>=0;i--)//由于要按存高位到低位输出,要从数组的尾部到开头进行检查
{
if(index[i]!=-1)//对是否是数据进行检查,-1则不输出
{
if(i==0)
printf("%s",numChar[index[i]]);//个位上的数是最后一位,后面不能有空格
else
printf("%s ",numChar[index[i]]);//其他位上后面均有数,需要有空格
}
}
return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值