题目如下:

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:

  1. -123456789

Sample Output 1:

  1. Fu yi Yi er Qian san Bai si Shi wu Wan liu Qian qi Bai ba Shi jiu

Sample Input 2:

  1. 100800

Sample Output 2:

  1. yi Shi Wan ling ba Bai

题目要求按照中国人的习惯阅读一个不超过9位的数字,这道题的坑比较多,一定要考虑到所有的情况。

首先要抓住规律,我们可以发现,一个数字的读法在每个4位是一致的。

例如12341234,我们读作“一千二百三十四万一千二百三十四”,我们可以看到除去万字以外读法完全一致。因此我们集中精力解决四位数的读法,然后加上亿、万等即可。

在解决的时候,注意0的读法,例如1000读作一千,而1050读作一千零五十,1005读作一千零五,另外根据题目要求,10读作一十而不是十。

四位的读法分析:一次性传入4位,高位允许全0,因为要处理不同部位的4位。

①一位数直接读,读作零到九。

②两位数判断十位是否是0,如果是,并且个位不是0,设个位为x,应该读作零x,例如10,0005,传入0005,整个数应该读作十万零五;如果十位为0并且个位为0,则不读。例如10,0000,万已经由高4位处理完毕,读作10万,低位不必读。

③三位数、四位数和两位数的思路一致,首先判断是否为0,如果发现当前位为0并且该位后面有不为0的,应该读一个零,注意不要读多了。

④一般情况只需要按照不同的位先输出数字,然后输出Qian Bai Shi即可,注意缩进处理。

把处理四位数的方法封装成一个函数。

整个数的处理方法为≤4位的直接用上面的函数,>4的截取不同的字符段来得到不同的位,每4位一截取。

代码如下:

  1. #include <iostream>
  2. #include <string>
  3. #include <string.h>
  4. #include <sstream>
  5. #include <stdio.h>
  6.  
  7. using namespace std;
  8.  
  9. char* values[] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
  10.  
  11. int char2int(char c){
  12. return c - '0';
  13. }
  14.  
  15. void handleNum(string num){
  16.  
  17. int bits = num.length();
  18.  
  19. bool printZero = false;
  20. switch(bits){
  21. case 1:{
  22. int ge = char2int(num[0]);
  23. printf("%s",values[ge]);
  24. break;
  25. }
  26. case 2:{
  27. int shi = char2int(num[0]);
  28. int ge = char2int(num[1]);
  29. if(shi != 0) printf("%s Shi",values[shi]);
  30. else if(!printZero){
  31. printf("ling");
  32. printZero = true;
  33. }
  34. if(ge != 0) printf(" %s",values[ge]);
  35. break;
  36. }
  37. case 3:{
  38. int bai = char2int(num[0]);
  39. int shi = char2int(num[1]);
  40. int ge = char2int(num[2]);
  41. if(bai != 0) {printf("%s Bai",values[bai]); printZero = false;}
  42. else if(!printZero && (shi !=0 || ge != 0)){
  43. printf("ling");
  44. printZero = true;
  45. }
  46. if(shi != 0) { printf(" %s Shi",values[shi]); printZero = false; }
  47. else if(!printZero && ge!=0){
  48. printf(" ling");
  49. printZero = true;
  50. }
  51. if(ge != 0) printf(" %s",values[ge]);
  52. break;
  53. }
  54. case 4:{
  55. int qian = char2int(num[0]);
  56. int bai = char2int(num[1]);
  57. int shi = char2int(num[2]);
  58. int ge = char2int(num[3]);
  59. if(qian != 0) {printf("%s Qian",values[qian]); printZero = false;}
  60. else if(!printZero && (bai!=0 || shi!=0 || ge!=0)){
  61. printf("ling");
  62. printZero = true;
  63. }
  64. if(bai != 0) {printf(" %s Bai",values[bai]); printZero = false;}
  65. else if(!printZero && (shi != 0 || ge != 0)){
  66. printf(" ling");
  67. printZero = true;
  68. }
  69. if(shi != 0) {printf(" %s Shi",values[shi]); printZero = false;}
  70. else if(!printZero && ge != 0){
  71. printf(" ling");
  72. printZero = true;
  73. }
  74. if(ge != 0) printf(" %s",values[ge]);
  75. }
  76. }
  77.  
  78. }
  79.  
  80. int main()
  81. {
  82. string num;
  83. cin >> num;
  84. if(num[0] == '-'){
  85. num = num.substr(1);
  86. cout << "Fu ";
  87. }
  88. int bits = num.length();
  89. switch(bits){
  90. case 1:
  91. case 2:
  92. case 3:
  93. case 4:
  94. handleNum(num);
  95. break;
  96. case 5:{
  97. int wan = char2int(num[0]);
  98. printf("%s Wan ",values[wan]);
  99. handleNum(num.substr(1));
  100. break;
  101. }
  102. case 6:{
  103. handleNum(num.substr(0,2));
  104. printf(" Wan ");
  105. handleNum(num.substr(2));
  106. break;
  107. }
  108. case 7:{
  109. handleNum(num.substr(0,3));
  110. printf(" Wan ");
  111. handleNum(num.substr(3));
  112. break;
  113. }
  114. case 8:{
  115. handleNum(num.substr(0,4));
  116. printf(" Wan ");
  117. handleNum(num.substr(4));
  118. break;
  119. }
  120. case 9:{
  121. handleNum(num.substr(0,1));
  122. printf(" Yi ");
  123. handleNum(num.substr(1,4));
  124. printf(" Wan ");
  125. handleNum(num.substr(5));
  126. break;
  127. }
  128. }
  129. return 0;
  130. }

1082. Read Number in Chinese (25)的更多相关文章

  1. 1082. Read Number in Chinese (25)-字符串处理

    题意就是给出9位以内的数字,按照汉子的读法读出来. 读法请看下方的几个例子: 5 0505 0505 伍亿零伍佰零伍万零伍佰零伍 5 5050 5050 伍亿伍仟零伍拾万伍仟零伍拾  (原本我以为这个 ...

  2. 1082 Read Number in Chinese (25分)

    // 1082.cpp : 定义控制台应用程序的入口点. // #include <iostream> #include <string> #include <vecto ...

  3. PAT (Advanced Level) 1082. Read Number in Chinese (25)

    模拟题. #include<cstdio> #include<cstring> #include<cmath> #include<vector> #in ...

  4. 【PAT甲级】1082 Read Number in Chinese (25 分)

    题意: 输入一个九位整数,输出它的汉字读法(用拼音表示). trick: 字符串数组""其实会输出一个空格,而不是什么都不输出,导致测试点0和4格式错误. AAAAAccepted ...

  5. pat1082. Read Number in Chinese (25)

    1082. Read Number in Chinese (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yu ...

  6. A1082 Read Number in Chinese (25 分)

    1082 Read Number in Chinese (25 分)   Given an integer with no more than 9 digits, you are supposed t ...

  7. 1082 Read Number in Chinese (25 分)

    1082 Read Number in Chinese (25 分) Given an integer with no more than 9 digits, you are supposed to ...

  8. PAT 1082 Read Number in Chinese[难]

    1082 Read Number in Chinese (25 分) Given an integer with no more than 9 digits, you are supposed to ...

  9. A1082 Read Number in Chinese (25)(25 分)

    A1082 Read Number in Chinese (25)(25 分) Given an integer with no more than 9 digits, you are suppose ...

随机推荐

  1. MVC简单随笔

    MVC的具体含义是:model+view+controller,即模型+视图+控制它们各自处理自己的任务: (1)模型(model):模型持有所有的数据.状态和程序逻辑.模型独立于视图和控制器.(2) ...

  2. MySQL数据库将多条记录的单个字段合并成一条记录

    原SQL AND acc.id = accRole.acc_id) AND accRole.role_id = T_PM_ROLE.id ORDER BY acc.id 结果,有一个人有两个角色,如果 ...

  3. js生成四位随机数的简便方法

    do out = Math.floor(Math.random()*10000); while( out < 1000 ) alert( out );

  4. python2.7入门---操作mysql数据库增删改查

    Python 标准数据库接口为 Python DB-API,Python DB-API为开发人员提供了数据库应用编程接口.Python 数据库接口支持非常多的数据库,你可以选择适合你项目的数据库: G ...

  5. 欢迎大家来到DevLegal的博客

    申明:以下博文欢迎转载,转载请注明出处和作者 若非作者原创,则会标记出处与原作者,其余则为原创. 本人在校大学僧一枚,软件工程专业,希望通过将自己的学习心得与体会写出来,勉励自己学习,同时与大家一起分 ...

  6. 关于 printf scanf getchar

    float默认小数6位 右对齐.-m 左对齐 在调用printf函数输出数据时,当数据的实际位宽大于printf函数中的指定位宽时,将按照数据的实际位宽输出数据. .n表精度 输出%符号 注意点 #i ...

  7. Python小代码_4_省市区三级菜单

    menu = { "北京": { "朝阳区": { "三环到四环之间": {}, "四环到五环之间": {}, &quo ...

  8. NPOI给单元格加范围边框

    HSSFWorkbook workbook2 = new HSSFWorkbook();        //XSSFWorkbook workbook2 = new XSSFWorkbook();// ...

  9. 【python进阶】Garbage collection垃圾回收2

    前言 在上一篇文章[python进阶]Garbage collection垃圾回收1,我们讲述了Garbage collection(GC垃圾回收),画说Ruby与Python垃圾回收,Python中 ...

  10. net框架运行原理

    核心是CLR(通用语言运行时), c#或者其它各种语言编译原理:将原代码通过相对的编译器(语法检查原代码分析)生成IL代码托管(IL也称托管代码),最后得到一个托管模块,一个或多个托管模块组成程序集( ...