本例用到了以下知识:
字符串拆成char,再计算,然后使用把int拆开,装在vector倒序输出。
1002 写出这个数
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
#include <iostream>
#include <vector>
#include <string>
using namespace std;
string Display(int temp)
{
string str;
switch(temp)
{
case 1:str = "yi"; break;
case 2:str = "er"; break;
case 3:str = "san"; break;
case 4:str = "si"; break;
case 5:str = "wu"; break;
case 6:str = "liu"; break;
case 7:str = "qi"; break;
case 8:str = "ba"; break;
case 9:str = "jiu"; break;
case 0:str = "ling";break;
}
return str;
}
int main()
{
char num[101] = {0};
char *pNum = num;
int sum = 0;
int temp = 1;
cin >> num;
while(*pNum != '\0')
{
sum += *pNum++ -'0';
}
// cout << sum<<endl; //test sum
vector<int> inVector;
while(sum)
{
temp = sum%10;
sum/= 10;
inVector.push_back(temp);
// cout << temp <<endl; //test
}
if (inVector.size()>0)
{
for (int i = inVector.size()-1;i>0;i--)
cout<< Display(inVector[i]).data()<<" ";
}
cout << Display(inVector[0]);
return 0;
}