12. Integer to Roman

/*
第二种是递归的方法,思路都是就是从大到小判断拆分,从前向后添加罗马数字
递归提交的时候出现超时现象
关键是理解罗马数字的组成方式,有几个临界点需要额外提取,其他的重复添加即可
可以百度以下罗马数字的组成方式。
 */
public String intToRoman(int num) {
    String str = "";
    String [] symbol = {"M","CM","D","CD","C","XC","L","XL","X","IX","V","IV","I"};
    int [] value = {1000,900,500,400, 100, 90,  50, 40,  10, 9,   5,  4,   1};
    for(int i=0;i<13;i++){
        while(num >= value[i]){
            num -= value[i];
            str += symbol[i];
        }
    }
    return str;
}
public String intToRoman2(int num){
    if(num>=1000) return "M"+intToRoman(num-1000);
    if(num>=900) return "CM"+intToRoman(num-900);
    if(num>=500) return "D"+intToRoman(num-500);
    if(num>=400) return "CD"+intToRoman(num-400);
    if(num>=100) return "C"+intToRoman(num-100);
    if(num>=90) return "XC"+intToRoman(num-90);
    if(num>=50) return "L"+intToRoman(num-50);
    if(num>=40) return "XL"+intToRoman(num-40);
    if(num>=10) return "X"+intToRoman(num-10);
    if(num>=9) return "IX"+intToRoman(num-9);
    if(num>=5) return "V"+intToRoman(num-5);
    if(num>=4) return "IV"+intToRoman(num-4);
    if(num>=1) return "I"+intToRoman(num-1);
    return "";
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值