Integer to Roman

本文深入探讨了将整数转换为罗马数字的算法实现,详细解释了命名规范的重要性,并提供了优化后的代码实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Integer to Roman

   

Given an integer, convert it to a roman numeral.

Input is guaranteed to be within the range from 1 to 3999.

备注:只要弄明白roman numeral, 这个题不算难,自己出现的

主要问题是在命名方面,注意:尽量少使用无法定义含义的名称,因为

后面很容易出现变量复用(i,j,k之类),这类的隐形错误使结果不正确,却又

难以发现原因。

class Solution {
public:
    string intToRoman(int num) {
        int len = 1000;
        string s = "";
        int n = num/len;
        int i ;
        for(i = 0;i< n;++i)
        s = s+"M";
        num =  num - n*len;
        len/=10; 
        n = num/len;
         i = 0;
        string str[] = {"CM","D","CD","C","XC","L","XL","X","IX","V","IV","I"};
        while(true)
        {
            if(n > 0)
            {
                    if(9 == n)
                    s = s+str[i]; 
                    else if(4 == n)
                    s = s+str[i+2];
                    else if(n >0 && n <4)
                    {
                        for(int k = 0;k < n;++k)
                        s = s+str[i+3];
                    }
                    else if(n > 4 && n < 9)
                    {
                        int j = n-5;
                        if(j == 0)
                        s = s+str[i+1];
                        else
                        {
                            s = s+str[i+1];
                            while(j > 0)
                            {
                                s = s+str[i+3];
                                --j;
                            }
                        }
                    }
            }
            i = i+4;
            if(i > 11)break;
            num = num-n*len;
            len/=10;
            if(len > 0)
            n = num/len;
        }
        return s;
    }
};


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值