码迷,mamicode.com
首页 > 其他好文 > 详细

[LeetCode] Integer to English Words

时间:2015-11-07 16:11:16      阅读:157      评论:0      收藏:0      [点我收藏+]

标签:

Convert a non-negative integer to its english words representation. Given input is guaranteed to be less than 231?1.

For example,

123 -> “One Hundred Twenty Three”
12345 -> “Twelve Thousand Three Hundred Forty Five”
1234567 -> “One Million Two Hundred Thirty Four Thousand Five Hundred Sixty Seven”

解题思路

略。

实现代码

// Runtime: 8 ms
class Solution {
public:
    string numberToWords(int num) {
        return num2str(num);
    }

private:
    string num2str(int num)
    {
        string res = "";
        if (num <= 19)
        {
            res += nums[num];
        }
        else if (num <= 99)
        {
            res += tens[num / 10];
            if (num % 10 != 0)
            {
                res += " ";
                res += num2str(num % 10);
            }
        }
        else if (num <= 999)
        {
            res += num2str(num / 100);
            res += " Hundred";
            if (num % 100 != 0)
            {
                res += " ";
                res += num2str(num % 100);
            }
        }
        else if (num <= 999999)
        {
            res += num2str(num / 1000);
            res += " Thousand";
            if (num % 1000 != 0)
            {
                res += " ";
                res += num2str(num % 1000);
            }
        }
        else if (num <= 999999999)
        {
            res += num2str(num / 1000000);
            res += " Million";
            if (num % 1000000 != 0)
            {
                res += " ";
                res += num2str(num % 1000000);
            }
        }
        else if (num <= 999999999999)
        {
            res += num2str(num / 1000000000);
            res += " Billion";
            if (num % 1000000000 != 0)
            {
                res += " ";
                res += num2str(num % 1000000000);
            }
        }

        return res;
    }

    string tens[10] = {"", "", "Twenty", "Thirty", "Forty", "Fifty", "Sixty", "Seventy", "Eighty", "Ninety"};

    string nums[20] = {"Zero", "One", "Two", "Three", "Four", "Five", "Six", "Seven", "Eight",
        "Nine", "Ten", "Eleven", "Twelve", "Thirteen", "Fourteen", "Fifteen", "Sixteen", "Seventeen",
        "Eighteen", "Nineteen"};
};

版权声明:本文为博主原创文章,未经博主允许不得转载。

[LeetCode] Integer to English Words

标签:

原文地址:http://blog.csdn.net/foreverling/article/details/49701899

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!