您的位置:首页 > 其它

13 Roman to Integer

2015-08-28 22:07 211 查看
/*

注意:

基本数字 Ⅰ、X 、C 中的任何一个、自身连用构成数目、或者放在大数的右边连用构成数目、都不能超过三个;放在大数的左边只能用一个;

不能把基本数字 V 、L 、D 中的任何一个作为小数放在大数的左边采用相减的方法构成数目;放在大数的右边采用相加的方式构成数目、只能使用一个;

V 和 X 左边的小数字只能用 Ⅰ;

L 和 C 左边的小数字只能用X;

D 和 M 左边的小数字只能用 C。

I(1)、V(5)、X(10)、L(50)、C(100)、D(500)、 M(1000)

*/

public class Solution {

public String intToRoman(int num) {

if(num==0) return null;

StringBuffer str = new StringBuffer();

//I(1)、V(5)、X(10)、L(50)、C(100)、D(500)、 M(1000)

String[] romans = {"M","CM","D","CD","C","XC","L","XL","X","IX","V","IV","I"};

int[] values = {1000,900,500,400,100,90,50,40,10,9,5,4,1};

int len = romans.length;

while(num>0){

for(int i=0;i<len;++i){

if(num>=values[i]){

str.append(romans[i]);

num -= values[i];

break;

}

}

}

return str.toString();

}

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