汉语博大精深,本问题要写一个函数将一个简单的阿拉伯数字转换为汉语中的读法。比如 1980,要转换为“一千九百八十”;198 要转换为“一百九十八”;19 要转换为“十九”等等。这属于细节处理问题。
特殊用例:
1、注意0的出现。1080、1008、1800、10000、1000000、100000000。
2、如果某个大权值内的四位都是0,比如100000500,那么不要这个大权值。
3、190000 一般读作“十九万” 而不是“一十九万”。这个情况最特殊。
数值:零一二三四五六七八九
小权值:十 百 千
大权值:万 亿
方法:
从右向左依次判断每个十进制位的数值(0~9)和小权值(十百千)。每四位结算一次并加入大权值(万亿)。
//暂时没有处理上面说的第三者特殊情况。
#include<iostream>
#include<string>
#include<vector>
using namespace std;
string transfer(int n)
{
string result;
vector<string> value = {"零","一", "二", "三","四", "五", "六", "七", "八", "九" };
vector<string> cost1 = {"", "十", "百" ,"千"};
vector<string> cost2 = {"", "", "万", "亿"};
if(n == 0)
return value[0];
int i, k;
string v, c1, c2, fourstr;
bool last0 = false;
bool tail0 = true;
bool all0 = true;
i = 0;
while(n!=0)
{
k = n%10;
v = value[k];
c1 = cost1[i%4];
if(i % 4 == 0) //每四位才出现一次
{
c2 = (all0==true) ? "" : cost2[i/4];
result = fourstr + c2 + result;
fourstr = "";
all0 = true;
}
if(k != 0) //非0
{
fourstr = v + c1 + fourstr;
tail0 = false;
all0 = false;
}
else //是0
{
if(last0 || tail0)
{
//连续的0,或者末尾的0
}
else //单独的0
{
fourstr = v + fourstr;
last0 = true;
}
}
//记得一定要自增~
i++;
n /= 10;
}
i--;
c2 = cost2[i/4+1];
result = fourstr + c2 +result;
return result;
}
int main()
{
int n;
while(cin>>n)
cout<<transfer(n)<<endl;
return 1;
}
上面代码是我自己测试的,没有经过哪个OJ系统的测试,因此绝对正确性还没能证实。希望各位来找茬。