请将给出的整数转化为罗马数字保证输入数字的范围在1 到 3999之间。

    public String intToRoman (int num) {
        // write code here
        //分别建立整数数组与对应的罗马字母字符串数组,从num高位依次转变,利用append()方法。
        int[] values={1000,900,500,400,100,90,50,40,10,9,5,4,1};
        String[] strs={"M","CM","D","CD","C","XC","L","XL","X","IX","V","IV","I"};

        //新建rom字符串变量
        StringBuilder rom=new StringBuilder();

        for(int i=0;i<values.length;i++){
            while(num>=values[i]){
                num-=values[i];
                rom.append(strs[i]);
            }
        }
        return rom.toString();
    }

请将给出的罗马数字转化为整数保证输入的数字范围在1 到 3999之间。

链接:https://www.nowcoder.com/questionTerminal/817fdd12bd3341349a0079f74e692ebf?f=discussion
来源:牛客网

/*
 * 基本字符 对应的数字
I 1
V 5
X 10
L 50
C 100
D 500
M 1000
相同的数字连写、所表示的数等于这些数字相加得到的数、如:Ⅲ=3;
小的数字在大的数字的右边、所表示的数等于这些数字相加得到的数、 如:Ⅷ=8、Ⅻ=12;
小的数字、(限于 Ⅰ、X 和 C)在大的数字的左边、所表示的数等于大数减小数得到的数、如:Ⅳ=4、Ⅸ=9;
正常使用时、连写的数字重复不得超过三次;
在一个数的上面画一条横线、表示这个数扩大 1000 倍。
 */

import java.util.*;
public class Solution {
    public int romanToInt(String s) {
        Map<Character, Integer> map = new HashMap<Character, Integer>();
        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 ans = 0;
        int preValue = 0;
        for (int i = s.length() - 1; i >= 0; i--) {
            int curValue = map.get(s.charAt(i));
            if (curValue < preValue)
                ans -= curValue;
            else
                ans += curValue;
            preValue = curValue;

        }
        return ans;

    }
}