int toNumber(char ch) {
        switch (ch) {
            case 'I': return 1;
            case 'V': return 5;
            case 'X': return 10;
            case 'L': return 50;
            case 'C': return 100;
            case 'D': return 500;
            case 'M': return 1000;
        }
        return 0;
 }

 


利用上述对应规则,实现罗马数字到整数的转换
 
罗马数字按照从后向前进行一次遍历,当后面的单位小于前面的单位时,直接加上该字符对应的数值;当后面的单位大于前面的单位时,需要减去该字符对应的数值。
 
参考代码:
package leetcode_50;

/***
 * 
 * @author pengfei_zheng
 * 罗马数字转为整数
 */
public class Solution13 {
    public int romanToInt(String s) {
        int len = s.length();
        int ans = toNumber(s.charAt(len-1));
        for(int i=len-2;i>=0;i--){
            int last = toNumber(s.charAt(i+1));
            int first = toNumber(s.charAt(i));
            if(first>=last){//后面字符单位小于前面字符单位,加上对应数字
                ans+=first;
            }
            else//减去对应数字
                ans-=first;
        }
        return ans;
    }
    int toNumber(char ch) {//对应转换规则
        switch (ch) {
            case 'I': return 1;
            case 'V': return 5;
            case 'X': return 10;
            case 'L': return 50;
            case 'C': return 100;
            case 'D': return 500;
            case 'M': return 1000;
        }
        return 0;
    }
}

 

 
 
 

相关文章:

  • 2021-05-26
  • 2021-07-08
  • 2022-01-28
  • 2022-01-12
  • 2021-06-18
  • 2021-09-21
  • 2021-12-08
  • 2021-11-23
猜你喜欢
  • 2021-11-18
  • 2021-09-21
  • 2022-01-31
  • 2021-09-25
  • 2022-01-19
  • 2022-12-23
  • 2021-05-22
相关资源
相似解决方案