1002. 写出这个数 (20)

xiaoxiao2021-02-28  33

问题描述

读入一个自然数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; sum += t; n /= 10; } sum = sum + n; cout << sum << endl; int j = 0; while(sum/10 !=0){ j = sum; sum /= 10; cout << a[sum] << " "; } cout << a[j]; return 0; }

尽管我将n的变量类型设为unsigned long long ,对于过长的数还是会出现越界。所以这段代码,仅对部分情况适用。

转载请注明原文地址: https://www.6miu.com/read-2250267.html

最新回复(0)