阿亮的算法之路——12. 整数转罗马数字

题目描述

题目描述1
题目描述2
一开始看到这题,想到的是动态规划、递归等,但是边想边写搞了半天,好像都不大好实现,索性来个简单的,大数字不就是由小数字起来的吗?

首次尝试

那我就搞个死循环,挨个的判断,由大到小,这个数如果大于等于1000,就给需要返回的字符串拼接一个“M”,然后将这个数字减去1000……直到最后这个数等于0,就将字符串返回。

    public static String intToRoman(int num)
    {
        StringBuilder re = new StringBuilder();
        while (num > 0)
        {
            if (num >= 1000)
            {
                re.append("M");
                num -= 1000;

            }
            else if (num >= 900)
            {
                re.append("CM");
                num -= 900;
            }
            else if (num >= 500)
            {
                re.append("D");
                num -= 500;
            }
            else if (num >= 400)
            {
                re.append("CD");
                num -= 400;
            }
            else if (num >= 100)
            {
                re.append("C");
                num -= 100;
            }
            else if (num >= 90)
            {
                re.append("XC");
                num -= 90;
            }
            else if (num >= 50)
            {
                re.append("L");
                num -= 50;
            }
            else if (num >= 40)
            {
                re.append("XL");
                num -= 40;
            }
            else if (num >= 10)
            {
                re.append("X");
                num -= 10;
            }
            else if (num >= 9)
            {
                re.append("IX");
                num -= 9;
            }
            else if (num >= 5)
            {
                re.append("V");
                num -= 5;
            }
            else if (num >= 4)
            {
                re.append("IV");
                num -= 4;
            }
            else
            {
                re.append("I");
                num -= 1;
            }
        }
        return re.toString();
    }

思路逻辑简单,代码也就那点。

提交结果

提交结果1

效果也还不错,我觉得如果第一时间想到了这种思路,这题难度不应该被归结为中等。

大佬思路

官方给出的题解和我上面的思路大致差不多,只是他用了两个来存这些特征数字和字符,不再重复。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值