LeetCode Java First 400 题解-013

这篇博客介绍了如何解决LeetCode上的第013题,即将给定的罗马数字转换成整数。题目保证输入在1到3999的范围内。解题思路主要涉及将罗马数字的每个字符根据其代表的数值累加,同时处理如'IV'(4)、'XL'(40)等特殊情况,确保结果正确。

Roman to Integer    Easy

Given a roman numeral, convert it to an integer.

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

public int romanToInt(String s) {

    int sum = 0;

    if (s.contains("IV")) {

        sum -= 2;

    }

    if (s.contains("IX")) {

        sum -= 2;

    }

    if (s.contains("XL")) {

        sum -= 20;

    }

    if (s.contains("XC")) {

        sum -= 20;

    }

    if (s.contains("CD")) {

        sum -= 200;

    }

    if (s.contains("CM")) {

        sum -= 200;

    }

    char c[] = s.toCharArray();

    int count = 0;

    for (; count <= s.length() - 1; count++) {

        if (c[count] == 'M') sum += 1000;

        if (c[count] == 'D') sum += 500;

        if (c[count] == 'C') sum += 100;

        if (c[count] == 'L') sum += 50;

        if (c[count] == 'X') sum += 10;

        if (c[count] == 'V') sum += 5;

        if (c[count] == 'I') sum += 1;

    }

    return sum;

}

思路:把所有出现的字符按次数相加即可。特殊情况:440之类的可使结果多出220,注意减去。因为限定了数值为13999,所以每种特殊情况只会出现一次。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值