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