当前位置: 代码迷 >> 综合 >> PAT (Basic Level) Practice (中文) 1002
  详细解决方案

PAT (Basic Level) Practice (中文) 1002

热度:103   发布时间:2023-11-26 22:19:02.0

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;
}
  相关解决方案