新手就是新手,这样一个看似简单的程序也想了好多天,最后还是看了提示,琢磨了一阵才写出来的。(提示是将阿拉伯数字从右到左,每四个分为一组,再将每一组转化为几仟几佰几拾几的形式,再将他们组合成为万,亿兆的形式),上代码。
#include<iostream>
using namespace std;
int count(int input) //计算数字的长度
{
int output=0;
if(input==0)
return 1;
while(input > 0)
{
input/=10;
output++;
}
return output;
}
string change(int num)//将每四个数字组转化为仟佰拾
{
string str="";
int temp=0;
int num_g=num;
int co=count(num_g);
for(int i=0;i<co;i++)
{
temp=num_g%10;
switch(temp)
{
case 0:str="零"+str;break;
case 1:str="壹"+str;break;
case 2:str="贰"+str;break;
case 3:str="叁"+str;break;
case 4:str="肆"+str;break;
case 5:str="伍"+str;break;
case 6:str="陆"+str;break;
case 7:str="柒"+str;break;
case 8:str="捌"+str;break;
case 9:str="玖"+str;break;
}
if(i==0&&i<co-1)
str="拾"+str;
else if(i==1&&i<co-1)
str="佰"+str;
else if(i==2&&i<co-1)
str="仟"+str;
num_g/=10;
}
return str;
}
string all_lj(__int64 num)//再将每个 数字组合并为万亿兆的形式
{
string str="";
for(int i=0;num!=0;i++)
{
int temp=num%10000;
num/=10000;
str=change(temp)+str;
if(i==0&&num!=0)
str="万"+str;
else if(i==1&&num!=0)
str="亿"+str;
else if(i==2&&num!=0)
str="兆"+str;
/* else
{
str=all_lj(num)+str;
num=0;
}*/
}
return str;
}
int main()
{
__int64 int num=0; //32位int不够用,用了64位的int
cin>>num;
cout<<all_lj(num)<<endl;
return 0;
}