PAT-1002写出这个数

1002 写出这个数 (20)(20 分)

读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10^100^。

输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。

输入样例:

1234567890987654321123456789

输出样例

yi san wu

1.下面这个程序是的第一种解法: 有点小缺点,只能满足输入的数字不能超过10的18次方.题目要求n小于10^100,这个是自己尝试了其他的办法.

#include <stdio.h>
	
int main(){
	long long n;
	long long  sum=0LL;
	char pinyin[][10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
	int a[100];
	int t=0; 
	//输出10的18次方以内没问题哦. 
	scanf("%lld",&n);
	//累加求n的各个位数之和 
	while(n!=0){
		sum=sum+n%10; 
		n=n/10;
	}
	//看看sum是几位数,用t记录位数,并把每个数字存在数组a中,
	while(sum!=0){
		a[t]=sum%10;//倒序存储,因为是从个位存的 
		sum=sum/10;
		t++;//记录位数 
	} 
	//嵌套数组映射,将数字转化成对应的拼音 
	for(int i=t;i>0;i--){
		printf("%s ",pinyin[a[i-1]]);
	}	
	return 0;
}

2.gets()方法在PAT的OJ上不能通过,最后采用C++的cin<<

#include<iostream>
#include <stdio.h>
#include <string.h>
using namespace std;
int main(){
	char pinyin[][10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
    char c[100];
    //gets(c);
    cin>>c;
    int a[10]={0};
    int sum=0;
   	int t=0;
    for(int i=0;i<strlen(c);i++){
    	sum=sum+c[i]-'0';
	}
	while(sum!=0){
		a[t]=sum%10;
		sum=sum/10;
		t++;
	}
	printf("%s ",pinyin[a[t-1]]);
	for(int j=t;j>1;j--){
		printf(" %s",pinyin[a[j-2]]);
	} 
	return 0; 
} 

3.第三方法代码能少点:

#include<cstdio>
int main()
{
    int sum=0; 
    char ch,s[4];                   //ch作为临时变量保存输入的每一个字符,s保存sum的每一个数字                        
    char b[10][5]={"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"};
    while ((ch = getchar()) != '\n')    //如果一直输入字符,不按回车的话 
        sum += (ch - '0');
    sprintf(s, "%d", sum);              // sprintf(char *buffer, const char *format,[ argument])将任意类型数据按某种格式转换成字符串 
    for (int i = 0; s[i] != 0; i++){
        if (i > 0) 
            printf(" ");
        printf("%s", b[s[i]-'0']);
    }
    return 0;
}

summary:

       整型和字符型可以通过ANSⅡ的值来互换,  0的ANSⅡ的值为 48.

       字符的'0','1','2','3','4'等等,可以通过给它们减去 48或者'0'就可以得到他们的整型值了.

        '9'-48=9;

        取个位的方法:  数字%10;就可以得到



猜你喜欢

转载自blog.csdn.net/qq_40959340/article/details/81012362