这个是傻逼做法。
#include <cstdio>
#include <algorithm>
#include <iostream>
#include <vector>
#include <string>
using namespace std;
int main(){
string str;
getline(cin, str);
int sum = 0;
for (int i = 0; i < str.size(); ++i) {
sum = sum + (str[i] - '0'); // 神来之笔好吧。
}
vector<int> num;
while(sum != 0){
int temp = sum % 10;
num.push_back(temp);
sum = sum / 10;
}
for(int i = num.size() - 1; i >= 0; i--){
if(i == 0){
switch (num[i]) {
case 1:
cout << "yi";
break;
case 2:
cout << "er";
break;
case 3:
cout << "san";
break;
case 4:
cout << "si";
break;
case 5:
cout << "wu";
break;
case 6:
cout << "liu";
break;
case 7:
cout << "qi";
break;
case 8:
cout << "ba";
break;
case 9:
cout << "jiu";
break;
case 0:
cout << "ling";
break;
}
}
else{
switch (num[i]) {
case 1:
cout << "yi" << " ";
break;
case 2:
cout << "er" << " ";
break;
case 3:
cout << "san" << " ";
break;
case 4:
cout << "si" << " ";
break;
case 5:
cout << "wu" << " ";
break;
case 6:
cout << "liu" << " ";
break;
case 7:
cout << "qi" << " ";
break;
case 8:
cout << "ba" << " ";
break;
case 9:
cout << "jiu" << " ";
break;
case 0:
cout << "ling" << " ";
break;
}
}
}
return 0;
}
这个是牛逼做法。
#include <iostream>
#include <string>
using namespace std;
int main() {
string pinyin[10] = {"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"}; // 拼音数组
string n;
cin >> n;
int sum = 0;
for (int i = 0; i < n.length(); i++) {
sum += n[i] - '0'; // 将字符转换为数字并累加
}
string s = to_string(sum); // 将数字转换为字符串
for (int i = 0; i < s.length(); i++) {
cout << pinyin[s[i] - '0']; // 输出拼音
if (i != s.length() - 1) {
cout << " "; // 最后一个拼音后不输出空格
}
}
return 0;
}
to_string
将数字转换为字符串。