现在的位置: 首页 > 综合 > 正文

c++阿拉伯数字转化为中文大写

2017年10月27日 ⁄ 综合 ⁄ 共 1202字 ⁄ 字号 评论关闭

新手就是新手,这样一个看似简单的程序也想了好多天,最后还是看了提示,琢磨了一阵才写出来的。(提示是将阿拉伯数字从右到左,每四个分为一组,再将每一组转化为几仟几佰几拾几的形式,再将他们组合成为万,亿兆的形式),上代码。

#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;
}

抱歉!评论已关闭.