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();
}
}
注意:
基本数字 Ⅰ、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();
}
}
相关文章推荐
- 母板页----路径问题
- CStatic控件的基本使用
- IOS 调发短信和邮件界面
- 正试图在 os 加载程序锁内执行托管代码。不要尝试在 DllMain 或映像初始化函数内运行托管代码
- Kth Largest Element in an Array
- MySQL 高可用浅析
- 母板页 难点---数据交换
- Android 网络请求超时处理方案
- 千王之王博客
- Java格式化CST日期时间
- Java格式化CST日期时间
- Java格式化CST日期时间
- 【转载】注入安卓进程,并hook java世界的方法
- easyui-editing datagrid 批量保存数据 一
- 获取指定URl页面中所有链接
- 关于 U-BOOT 中 SPL 的移植 二
- 运维规范:执行写入操作时,一定不要开两个分别连入不同主机的securCRT窗口
- 微信支付
- 用户控件(二)--常见4 种路径问题解决:
- 行为分析综述