leetcode-13-罗马数字转整数

 

问题:

 

 

解:

package com.example.demo;

import java.util.HashMap;
import java.util.Map;

public class Test13 {

    /**
     * 罗马数字转整数
     * 罗马字符前边的都比后边的字符大,根据这个特点,设置两个指针,一个是当前current代表当前的数字,
     * 一个pre代表之前的那个数字,在累加的时候判断current和pre的大小,如果pre< current时,代表数字加错,将
     * pre减2次即可(减2次是因为,本来不应该加的数,加了,另一次是本来该减的,还是加了 )
     * 例如:IV
     * 错误的结果是:  1 + 5 = 6    ==>   1 不应该加,因为I和后边的V是一个数,后边又加了一个I   也就是加了两次I
     * 所以需要减掉两个I
     * 正确的结果: 4
     *
     * @param s
     * @return
     */
    public int romanToInt(String s) {
        Map<Character, Integer> map = new HashMap<>();
        map.put('I', 1);
        map.put('V', 5);
        map.put('X', 10);
        map.put('L', 50);
        map.put('C', 100);
        map.put('D', 500);
        map.put('M', 1000);

        int res = 0;
        char[] chars = s.toCharArray();
        int pre = 1000;
        for (char c : chars) {
            Integer current = map.get(c);
            res += current;
            if (current > pre) {
                res = res - pre * 2;
            }
            pre = current;
        }
        return res;
    }

    public static void main(String[] args) {
        Test13 t = new Test13();
        int i = t.romanToInt("MCMXCIV");
        System.out.println(i);
    }
}

 

posted @ 2019-07-28 00:44  xj-record  阅读(213)  评论(0编辑  收藏  举报