07-0. 写出这个数 (20)
时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
CHEN, Yue
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:1234567890987654321123456789输出样例:
yi san wu
提交代码
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int main()
{
char IG[101];
memset(IG,0,sizeof(IG));
gets(IG);
int N=0;
for(int i=0;i<strlen(IG);i++)
{
int temp=IG[i]-'0';
N+=temp;
}
int LGD[101];
int i=0;
while(N/10!=0)
{
LGD[i]=N%10;
//printf("%d ",LGD[i]);
N=N/10;
i++;
}
LGD[i]=N;
int n;
char skt[101];
memset(skt,0,sizeof(skt));
for(int j=i;j>=0;j--)
{
n=LGD[j];
switch(n)
{
case 0:
strcat(skt,"ling ");break;
case 1:
strcat(skt,"yi ");break;
case 2:
strcat(skt,"er ");break;
case 3:
strcat(skt,"san ");break;
case 4:
strcat(skt,"si ");break;
case 5:
strcat(skt,"wu ");break;
case 6:
strcat(skt,"liu ");break;
case 7:
strcat(skt,"qi ");break;
case 8:
strcat(skt,"ba ");break;
case 9:
strcat(skt,"jiu ");break;
default:
break;
}
}
for(int j=0;j<strlen(skt)-1;j++)
printf("%c",skt[j]);
printf(" ");
//printf("%d ",LGD[i]);
return 0;
}
#include<string.h>
#include<stdlib.h>
int main()
{
char IG[101];
memset(IG,0,sizeof(IG));
gets(IG);
int N=0;
for(int i=0;i<strlen(IG);i++)
{
int temp=IG[i]-'0';
N+=temp;
}
int LGD[101];
int i=0;
while(N/10!=0)
{
LGD[i]=N%10;
//printf("%d ",LGD[i]);
N=N/10;
i++;
}
LGD[i]=N;
int n;
char skt[101];
memset(skt,0,sizeof(skt));
for(int j=i;j>=0;j--)
{
n=LGD[j];
switch(n)
{
case 0:
strcat(skt,"ling ");break;
case 1:
strcat(skt,"yi ");break;
case 2:
strcat(skt,"er ");break;
case 3:
strcat(skt,"san ");break;
case 4:
strcat(skt,"si ");break;
case 5:
strcat(skt,"wu ");break;
case 6:
strcat(skt,"liu ");break;
case 7:
strcat(skt,"qi ");break;
case 8:
strcat(skt,"ba ");break;
case 9:
strcat(skt,"jiu ");break;
default:
break;
}
}
for(int j=0;j<strlen(skt)-1;j++)
printf("%c",skt[j]);
printf(" ");
//printf("%d ",LGD[i]);
return 0;
}