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>
#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;
}
#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;
}