PAT 1002 写出这个数
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100 。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
对于这个题可以一步一步按题中要求来临摹。
我找了两种方法,但是第二种在网站上无法运行,c的版本不支持,所以可以参考第一种方法,代码简单,但是好理解一些
#include<stdio.h>
#include<math.h>
#include<string.h>
int main()
{
char ch; //用于输入
int sum = 0; //表示用来表示条件转化后的数
while( (ch = getchar() ) != '\n') //转化题中的条件 ,不用计算数字大小,用字符型代替,可无限输入
{
switch(ch)
{
case '1':
{
sum += 1;
break;
}
case '2':
{
sum += 2;
break;
}
case '3':
{
sum += 3;
break;
}
case '4':
{
sum += 4;
break;
}
case '5':
{
sum += 5;
break;
}
case '6':
{
sum += 6;
break;
}
case '7':
{
sum += 7;
break;
}
case '8':
{
sum += 8;
break;
}
case '9':
{
sum += 9;
break;
}
case '0':
break;
}
}
char a[4];
int i = 0;
while(sum != 0) //将整型拆分成对应位置的字符型数据,储存在数组 a 中
{
a[i] = sum%10 + 48;
sum /= 10;
i++;
}
int s = 0;
for(;i >= 0;i--)
{
switch(a[i])
{
case '1':
{
printf("yi");
if(i != s)
printf(" ");
break;
}
case '2':
{
printf("er");
if(i != s)
printf(" ");
break;
}
case '3':
{
printf("san");
if(i != s)
printf(" ");
break;
}
case '4':
{
printf("si");
if(i != s)
printf(" ");
break;
}
case '5':
printf("wu");
if(i != s)
printf(" ");
break;
case '6':
{
printf("liu");
if(i != s)
printf(" ");
break;
}
case '7':
{
printf("qi");
if(i != s)
printf(" ");
break;
}
case '8':
{
printf("ba");
if(i != s)
printf(" ");
break;
}
case '9':
{
printf("jiu");
if(i != s)
printf(" ");
break;
}
case '0':
{
printf("ling");
if(i != s)
printf(" ");
break;
}
}
}
// char a[4];
//
// sprintf(a,"%d",sum); //将整型转化为字符型 ,储存在数组 a 中
// int s = strlen(a);
//
printf("%d\n",s);
//
// int i = 0;
// while(a[i] != '\0')
// {
// switch(a[i])
// {
// case '1':
// {
// printf("yi");
// if(i != s)
// printf(" ");
// break;
// }
// case '2':
// {
// printf("er");
// if(i != s)
// printf(" ");
// break;
// }
// case '3':
// {
// printf("san");
// if(i != s)
// printf(" ");
// break;
// }
// case '4':
// {
// printf("si");
// if(i != s)
// printf(" ");
// break;
// }
//
// case '5':
// printf("wu");
// if(i != s)
// printf(" ");
// break;
//
// case '6':
// {
// printf("liu");
// if(i != s)
// printf(" ");
// break;
// }
// case '7':
// {
// printf("qi");
// if(i != s)
// printf(" ");
// break;
// }
// case '8':
// {
// printf("ba");
// if(i != s)
// printf(" ");
// break;
// }
// case '9':
// {
// printf("jiu");
// if(i != s)
// printf(" ");
// break;
// }
// case '0':
// {
// printf("ling");
// if(i != s)
// printf(" ");
// break;
// }
// }
//
// i++;
// }
return 0;
}