走过的坑:
有一定基础的同学知道输入的数字超过了一般int,long型的位数。起初写了一个错误的代码,没有考虑用char,小范围的n可以通过:
#include<iostream>
#include<math.h>
using namespace std;
int main()
{
char *shuzi[10]={(char*)"ling",(char*)"yi",(char*)"er",(char*)"san",(char*)"si",(char*)"wu",(char*)"liu",(char*)"qi",(char*)"ba",(char*)"jiu"};
int x,yushu,shang,sum=0;
cin>>x;
while(x!=0)
{
yushu=x%10;
sum += yushu;
x=x/10;
}
int count=0,sum1=sum;
while(sum1!=0)
{
yushu=sum1%10;
sum1 = sum1/10;
count++;
}
while(count!=0)
{
shang=sum/(int)pow(10,(count-1));
if(count!=1)
{
cout<<shuzi[shang]<<" ";
}
else
{
cout<<shuzi[shang]<<"";
}
sum=sum%(int)pow(10,(count)-1);
count--;
}
}
重新来过:
主要运用了c++里面字符串系列的操作。期间dev c++里stoi函数不能用,需要自己设置一下。
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s;
cin>>s;
int sum=0;
for (int i=0;i<s.size();i++)
{
sum += stoi(s.substr(i,1));
}
string sum1 = to_string(sum);
string shuzi[] = { "ling", "yi", "er", "san", "si", "wu", "liu","qi","ba","jiu"};
for (int i=0;i<sum1.size();i++)
{
if (i!=sum1.size()-1)
{
cout<<shuzi[stoi(sum1.substr(i,1))]<<" ";
}
else
{
cout<<shuzi[stoi(sum1.substr(i,1))];
}
}
}