【PAT】1082 Read Number in Chinese (25 分)

46 篇文章 0 订阅
44 篇文章 0 订阅
  • 题目大意:将数字按照中文的方式输出,若数字中有0,则按中国传统方式输出,例如:100800 is yi Shi Wan ling ba Bai

  • 思路:

    1. 找规律!!!
      1. 先考虑无0的情况:除了个位数,每次读数字都得 先读数字,再读单位
      2. 再考虑有0的情况
        • case 1 最后一个0在万级以上的位置:只读“ 零”
        • case 2 最后一个0在万级以上的位置:
          • case 2.1 万级位为0,读”万 零“
          • case 2.2 万级位不为0,读” 零“
  • 知识点

    1. hash:用字符串vector存数字和单位的拼音
    2. stoi():只能将string型变量变成int类型变量(字符、字符数组不行!)
  • 代码:

    #include <iostream>
    #include <string>
    #include <vector>
    using namespace std;
    
    int main(){
        string n;
        vector<string> a = {"yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"};
        vector<string> b = {"", "Shi", "Bai", "Qian", "Wan", "Shi", "Bai", "Qian", "Yi"};   // 从低到高。b[0]是个位数
        cin >> n;
    
        if(stoi(n) == 0)    // 一定要考虑n == 0的情况!
            printf("ling");
        if(n[0] == '-') // 有负号的情况
            printf("Fu");
        for(int i = 0; i < n.length(); i++){
            if(n[i] == '-')   continue; // 上面输出了负号,所以跳过
            if(n[i] == '0') continue;   // 是0就跳过
            else{
                if(i > 0 && n[i - 1] == '0'){   // 分析前面有0的情况:case 1 最后一个0在万级以上的位置; case 2 最后一个0在万级及万级以下的位置
                    if(n.length() - i + 1 > 5) // case 1
                        printf(" ling");
                    else if(n.length() - i + 1 <= 5){   // case 2
                        if(n[n.length() - 5] == '0')   // case 2.1 若万级位置为0
                            printf(" Wan ling");
                        else   // case 2.2 若万级位置不为0
                            printf(" ling");
                    }
                }
                if(i != 0)
                    printf(" ");
                if(i == n.length() - 1) // 个位数没有单位,所以只要输出数值
                    printf("%s", a[n[i] - '0' - 1].c_str());
                else
                    printf("%s %s", a[n[i] - '0' - 1].c_str(), b[n.length() - i - 1].c_str());  // 无0的情况:输出这个数字的数值和单位
            }
        }
        return 0;
    }
    
  • 总结:

    1. 要学会分析问题找规律!!!
    2. 不要在一个问题上拖太久,这道题卡了我一天,心态差点崩了…T T
    3. stoi():只能将string型变量变成int类型变量(字符、字符数组不行!)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值