问题描述
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:1234567890987654321123456789输出样例:
yi san wu
代码
#include <stdio.h>
int main()
{
int sum = 0;
char c, *a[] = {"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"};// a是数组, 数组中的元素是指针, 指向char类型
/* 将输入的字符串各位求和 */
while((c = getchar()) != '\n')
{
sum += c - '0'; // c - '0'实现字符到数字的转化
}
if(sum / 100) /* 打印百位 */
{
printf("%s ", a[sum / 100]);
}
if(sum / 10) /* 打印十位 */
{
printf("%s ", a[sum / 10 % 10]);
}
printf("%s", a[sum % 10]); /* 打印个位 */
return 0;
}
分析:对于这题而言,之所以可以只分3种情况来讨论,是因为n<10^100, 对于一个给定的n的各位之和最大不会超过100个9相加,也就是说所得的sum最多不过是个3位数。故可用上述的方法实现。
不过最初在看到这道题时,因为没有考虑到sum的界限、输入值的越界问题,以及对字符串的运用不熟悉等诸多因素,走的不少弯路。
下面是代码的错误示范:
#include <iostream>
using namespace std;
int main()
{
char *a[10] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
/*a[10]只是一个字符串数组,对其给它赋了很多初始值,并且是字符串型的,
会出现too many initializers,定义一个字符串指针数组就可以解决这个问题*/
unsigned long long n = 0;
cin >> n;
int sum = 0;
int t = 0;
while(n/10 !=0){
t = n%10;
sum += t;
n /= 10;
}
sum = sum + n;
cout << sum << endl;
int j = 0;
while(sum/10 !=0){
j = sum%10;
sum /= 10;
cout << a[sum] << " ";
}
cout << a[j];
return 0;
}
尽管我将n的变量类型设为unsigned long long ,对于过长的数还是会出现越界。所以这段代码,仅对部分情况适用。