1082 Read Number in Chinese (25 分)

字符串处理问题,对我来说很难的一道题,做了两遍看答案才做出来,坑点如下
1,用left和right将数据分块处理,一个单元一个单元的依次处理;
2,ling的情况,使用flag记录是否存在多余的零
3,如果一个单元没有输出一个字符,则不必输入后边的位,如(800000008)省略万位。
代码如下

#include<algorithm>
#include<cstring>
using namespace std;
char a[12];
char b[12];
char c[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
char wei[5][5]={"Shi","Bai","Qian","Wan","Yi"};

int main(){
   scanf("%s",a);
   int len=strlen(a);
   int left=0,right=len-1;
   if(a[0]=='-')
   {printf("Fu");
    left++;
   }
    while(left+4<=right)
    { right=right-4;
    }
    while(left<len)
    {  bool flag=false;
       bool isprint=false;
        while(left<=right){
            if(left>0&&a[left]=='0'){
flag=true;}
            else{
                if(flag==true){
                    printf(" ling");
                    flag=false;
                }
            
            if(left>0) printf(" ");
               printf("%s",c[a[left]-'0']);
                isprint=true;
            if(left!=right){
                printf(" %s",wei[right-left-1]);
            }
            }
            left++;
        }
     
        if(isprint==true&&right!=len-1){
            printf(" %s",wei[(len-right)/4+2]);
        }
     right+=4;
    }
    return 0;
    
   
    
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值