面试题 16.08. 整数的英语表示

链接:面试题 16.08. 整数的英语表示

class Solution {
public:
    std::vector<std::string> singles= {"", "One", "Two", "Three", "Four", "Five", "Six", "Seven", "Eight", "Nine"};
    std::vector<std::string> teens = {"Ten", "Eleven", "Twelve", "Thirteen", "Fourteen", "Fifteen", "Sixteen", "Seventeen", "Eighteen", "Nineteen"};
    std::vector<std::string> tens = {"", "", "Twenty", "Thirty", "Forty", "Fifty", "Sixty", "Seventy", "Eighty", "Ninety"};
    std::vector<std::string> thousands = {"", "Thousand", "Million", "Billion"};
    string numberToWords(int num) {
        // 2^31 - 1 int最大值21亿
        if (num == 0) {
            return "Zero";
        }
        std::string sb;
        for (int i = 3, unit = 1000000000; i >= 0; --i, unit /= 1000) {
            int cur = num / unit;
            if (cur != 0) {
                sb += to_engish(cur) + thousands[i] + " ";
                num -= cur * unit;
            }
        }
        // 排出最后面的空格
        while (sb.back() == ' ') {
            sb.pop_back();
        }
        return sb;
    }
    std::string to_engish(int num) {
       // cout << num << endl;
        std::string sb;
        int houndred = num / 100;
        if (houndred !=0) {
            sb = singles[houndred] + " Hundred ";
        }
        num %= 100;
        cout << num << endl;
        int ten = num / 10;
        if (ten == 1) {       // cout << num << endl;
            // 这个地方是num-10
            sb += teens[num-10] + " ";
        //cout << num << endl;

            return sb;
        } else if (ten >= 2) { // 排出十位为0的情况
            sb += tens[ten] + " ";
        }
        num %= 10;
        cout << num << endl;
        // 排出个位为0的情况
        if (num != 0) {
            sb += singles[num] + " ";
        }
        return sb;
    }
};

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值