Pat1082代码
Given an integer with no more than 9 digits, you are supposed to read it in the traditional Chinese way. Output "Fu" first if it is negative. For example, -123456789 is read as "Fu yi Yi er Qian san Bai si Shi wu Wan liu Qian qi Bai ba Shi jiu". Note: zero ("ling") must be handled correctly according to the Chinese tradition. For example, 100800 is "yi Shi Wan ling ba Bai".
Input Specification:
Each input file contains one test case, which gives an integer with no more than 9 digits.
Output Specification:
For each test case, print in a line the Chinese way of reading the number. The characters are separated by a space and there must be no extra space at the end of the line.
Sample Input 1:-123456789Sample Output 1:
Fu yi Yi er Qian san Bai si Shi wu Wan liu Qian qi Bai ba Shi jiuSample Input 2:
100800Sample Output 2:
yi Shi Wan ling ba Bai
#include<cstdio>
#include<string>
#include<vector>
using namespace std;
int main(int argc,char *argv[])
{
string d[]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
string w[]={"0","Shi","Bai","Qian","Wan","Shi","Bai","Qian","Yi"};
vector<string> ans;
vector<int> num;
int n,e;
scanf("%d",&n);
if(n==0)
{
printf("ling\n");
return 0;
}
else if(n<0)
{
printf("Fu ");
n=-n;
}
while(n)
{
num.push_back(n%10);
n/=10;
}
e=0;
while(e<num.size()&&num[e]==0)
{
e++;
}
if(e==8)
{
printf("%s Yi\n",d[num[e]].c_str());
return 0;
}
for(int i=e;i<num.size();i++)
{
if(i!=0&&(num[i]!=0||i==4||i==8))
{
ans.push_back(w[i]);
}
ans.push_back(d[num[i]]);
}
for(int i=ans.size()-1;i>=0;i--)
{
if(i!=ans.size()-1)
printf(" ");
int cnt=0;
while(i>=0&&ans[i]=="ling")
{
--i;
++cnt;
}
if(cnt!=0&&ans[i]!="Wan")
{
printf("ling ");
}
printf("%s",(ans[i]).c_str());
}
printf("\n");
return 0;
}