2021-03-08

public class Solution {
    public string IntToRoman(int num) {
        string Rstr = string.Empty;

            int len = num.ToString().Length;
            char[] Test = num.ToString().ToCharArray();
            int I = 0;
            //主要处理进度和4与6情况下
            while (I< len)
            {
                int GWS = Convert.ToInt32(Test[I].ToString());
                switch (len-I)
                {
                    case 1:
                        Rstr = Rstr + RomChange("I", "V", "X", GWS);
                        break;
                    case 2:
                        Rstr = Rstr + RomChange("X", "L", "C", GWS);
                        break;
                    case 3:
                        Rstr = Rstr + RomChange("C", "D", "M", GWS);
                        break;
                    case 4:
                        Rstr = Rstr + RomChange("M", "Z", "Z", GWS);
                        break;
                    default:
                        Rstr = Rstr + RomChange("I", "V", "X", GWS);
                        break;
                }
                I++;
            }

            return Rstr;
    }

    private string RomChange(string start, string Half,string All,int Dia)
        {
            string returnStr = string.Empty;
            int ZS = 0;
            int YS = 0;

            ZS = Dia/5;
            YS = Dia%5;

            if (YS == 4)
            {
                returnStr = ZS > 0 ? start + All : start + Half;
            }
            else
            {
                while (YS > 0)
                {
                    returnStr = returnStr + start;
                    YS = YS - 1;
                }
                returnStr = (ZS > 0 ? Half : string.Empty) + returnStr;
            }

            return returnStr;
        }
}

LetCode整数转罗马数字的解法!

本题主要是要处理的对数据进行位移处理。本题刚开始没注意性能,通过Math.Floor(num/(Math.Pow(10, len - 1)))获取最左那位数字,然后在用num减去GWS * (int)Math.Pow(10, len - 1)用于下次再计算这种方式性能太差了,后来看了他人的解决思路,改成直接读取字符性能立马提升

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值