这道题也算是比较考察小白细节的一道题吧,主要是考虑字符串与整型之间的转换
在字符后面加一个 “-‘0’”,这样就可以对字符进行整数转换了简单的方法
原理是:
字符‘0’对应的ASCII码是48,48对应的十六进制数就是0x30,通常我们在编程的时候,用字符转化为数字的时候经常要用到,比如要将‘2’转换为数字2,在语句中这样写就可以了,“ 2 - ‘0’”。这里的2就是数字了。
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
代码:
#include <iostream>
#include <string>
#include <sstream>
using namespace std;
int main() {
string num[10] = { "ling","yi","er","san"
,"si","wu","liu","qi","ba","jiu" };
string a = "";
cin >> a;
string c,str;
stringstream iss; // 运用了stringstream进行由整型到字符型的转换
int b = 0 ;
for (int i = 0;i< a.length();++i ){
b += a[i] - '0'; 用-‘0’实现了由字符型到整型的转换
}
iss << b;
iss >> str;// 运用了stringstream进行由整型到字符型的转换
for (int j = 0; j < str.length(); ++j) {
c = num[str[j] - '0'];
if (j < str.length() - 1)
cout << c << " ";
}
cout <<c;
return 0;
}