您的位置:首页 > 其它

LeetCode Roman to Integer

2016-02-21 09:01 393 查看
题目

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”

首先要来了解一下罗马数字表示法,基本字符有7个:I,V,X,L,C,D,M,分别表示1,5,10,50,

100,500,1000。

在构成数字的时候,有下列规则:

1、相同的数字连写,所表示的数等于这些数字相加得到的数,如:Ⅲ = 3;

2、小的数字在大的数字的右边,所表示的数等于这些数字相加得到的数, 如:Ⅷ = 8;Ⅻ = 12;

3、小的数字,(限于Ⅰ、X 和C)在大的数字的左边,所表示的数等于大数减小数得到的数,如:Ⅳ= 4;Ⅸ= 9;

4、正常使用时,连写的数字重复不得超过三次。

通过建立一个Map,存储罗马数字对应的整数么,然后去查找当前罗马数字对应的整数a与右边的罗马

数字所对应的整数b进行比较,如果a>=b,则相加,否则相减。代码如下:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: