#C
原始版本:
#include <stdio.h>
#include<string.h>
#include<math.h>
int main()
{
int a,s=0,i,d;
char x[105];
int len(int s);
gets(x);
for(i=0;i<strlen(x);i++)
{
s=s+x[i]-'0';// or s=s+x[i]-48
}
d=len(s);
for(i=0;i<d;i++)
{
a=s/pow(10,len(s)-1);
s=s-a*pow(10,(len(s)-1));
switch(a)
{ case 0:printf("ling"); break;
case 1:printf("yi");break;
case 2:printf("er");break;
case 3:printf("san");break;
case 4:printf("si");break;
case 5:printf("wu");break;
case 6:printf("liu");break;
case 7:printf("qi");break;
case 8:printf("ba");break;
case 9:printf("jiu");break; }
if(i!=d-1)
printf(" ");
}
}
int len(int s)
{
int count=0;
while(s!=0){
s=s/10;
count++;
}
return count;
}
改良版本,借鉴了别人的想法:
#include <stdio.h>
#include <string.h>
int main()
{
char c[105];//位数,多留几位
int a[5];//一百个9也就900
char pinyin[][5] = { "ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int i,n,t;
n = 0;
t = 0;
gets(c);
for(i=0;i<strlen(c);i++)
n = n + c[i] - 48;
while (n!=0)
{
a[t] = n%10;
n = n/10;
t++;
}//取每一位头数,倒着取
printf("%s",pinyin[a[t-1]]);
for(i=t-2;i>=0;i--)
printf(" %s",pinyin[a[i]]);//最后不要空格
}
#python
x=int(input())
s=0
while x!=0:
a=x%10
x=x//10
s=s+a
d={'0':'ling','1':'yi','2':'er','3':'san','4':'si','5':'wu','6':'liu','7':'qi','8':'ba','9':'jiu'}
s=str(s)
for i in range(len(s)):
if i==len(s)-1:
print(d.get(s[i]))
else:
print(d.get(s[i]),end=" ")