发布于 2014-10-17 07:34:16 | 169 次阅读 | 评论: 0 | 来源: 网友投递

这里有新鲜出炉的精品教程,程序狗速度看过来!

去哪儿网

去哪儿网(Qunar.com)总部位于北京,于2005年5月,由庄辰超与戴福瑞(Fritz Demopoulos)、道格拉斯(Douglas Khoo)共同创立。作为中国第一个旅游搜索引擎,使中国旅行者首次能够在线比较国内航班和酒店的价格及服务。


给你一串中文大写数字,比如:贰仟零伍亿叁仟陆佰万零叁拾。要求输出他的运行结果,为:200536000030。

参考答案:

  1. #include <cstdio>  
  2. #include <cstring>  
  3. #include <iostream>  
  4. #include <algorithm>  
  5. using namespace std;  
  6. char yi[3] = {"亿"} , wan[3] = {"万"} , qian[3] = {"仟"} , bai[3] = {"佰"} , shi[3] = {"拾"};  
  7. char num[10][3] = {"零","壹","贰","叁","肆","伍","陆","柒","捌","玖"};//贰仟零伍亿叁仟陆佰万零叁拾  
  8. int tmp[4] , a[20];  
  9. char s[1010];  
  10. int check(int p) {  
  11.     if(strncmp(num[0],s+p,2) == 0) return 1;  
  12.     for(int i=1;i<10;i++) if(strncmp(num[i],s+p,2) == 0) return i;  
  13.     return 0;  
  14. }  
  15. void func(int L,int R) {  
  16.     memset(tmp,0,sizeof(tmp));  
  17.     for(int i=L;i<=R;i++) {  
  18.         if(strncmp(s+i,qian,2) == 0) tmp[0] = check(i-2);  
  19.         if(strncmp(s+i,bai,2) == 0) tmp[1] = check(i-2);  
  20.         if(strncmp(s+i,shi,2) == 0) tmp[2] = check(i-2);  
  21.         if(strncmp(s+i,shi,2) == 0) tmp[3] = check(i+2);  
  22.     }  
  23.     if(strncmp(s+R-1,shi,2) != 0) {  
  24.         tmp[3] = check(R-1);  
  25.     }  
  26. }  
  27. void solve() {  
  28.     memset(a , 0 ,sizeof(a));  
  29.     int len = strlen(s);  
  30.     int l = 0;  
  31.     for(int i=0;i<len;i++) {  
  32.         if(strncmp(s+i,yi,2) == 0) {  
  33.             func(l , i-1);  
  34.             l = i + 2;  
  35.             for(int j=0;j<4;j++) a[j] = tmp[j];  
  36.             break;  
  37.         }  
  38.     }  
  39.     for(int i=l;i<len;i++) {  
  40.         if(strncmp(s+i,wan,2) == 0) {  
  41.             func(l , i-1);  
  42.             l = i + 2;  
  43.             for(int j=0;j<4;j++) a[4+j] = tmp[j];  
  44.             break;  
  45.         }  
  46.     }  
  47.     func(l , len-1);  
  48.     for(int j=0;j<4;j++) a[8+j] = tmp[j];  
  49.     int i = 0;  
  50.     for(i=0;!a[i];i++);  
  51.     for(;i<12;i++) printf("%d" , a[i]);  
  52. }  
  53. int main() {  
  54.     scanf("%s" , s);  
  55.     solve();  


最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务