1002 写出这个数 (20 分)
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
经验总结:要判断出高位是否为0,因此通过if判断将高位非0的去掉后保存进数组,然后在进行调用。先前数值部分失败原因即高位0的问题
#include<iostream>
#include<string.h>
#define maxsize 10000
using namespace std;
void choise(int b);
int main()
{ char data[maxsize];
int v,sum=0,a1,a2,a3,a4,DATA[maxsize],DATA2[maxsize],t=0,i=0,flag=1,d=0;
scanf("%s",data);
v=strlen(data);
for(int i=0;i<v;i++)
sum+=data[i]-'0';
t=sum;
while(t)
{DATA[i++]=t%10;
t=t/10;
}
for(int j=i-1;j>=0;j--)
{
if(DATA==0&&flag==1)
flag=0;
else if(DATA!=0)
flag=1;
if(flag==1)
DATA2[d++]=DATA[j];
}
for(int v=0;v<d;v++)
{//cout<<DATA2[v];
choise(DATA2[v]);
if(v<d-1)
cout<<" ";
}
}
void choise(int b)
{ char a[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
printf("%s",a[b]);
}