罗马数字是采用七个罗马字母作数字、即Ⅰ(1)、V(5)、X(10)、L(50)、C(100)、C(500)、M(1000) 记数的方法:
- 相同的数字连写,所表示的数等于这些数字相加得到的数,如 III = 3;
- 小的数字在大的数字的右边,所表示的数等于这些数字相加得到的数,如 VII=7、XVI=16;
- 小的数字(限于 Ⅰ、X 和 C)在大的数字的左边,所表示的数等于大数减小数得到的数,如 Ⅳ=4、Ⅸ=9;
- 在一个数的上面画一条横线,表示这个数增值 1,000 倍,如=5000。
输入: 'IX'
输出: 9
解 : I小于X=9 个人理解
输入: 'MD'
输出: 1500
解 : M大于D=1500 个人理解
输入: 'XLIX'
输出: 49
解 : X小于L=40 I小于X=9 个人理解
输入: 'XLVIII'
输出: 48
解 : X小于L=40 V大于I=8 个人理解
这里肯定有人想,用 IL 不就可以了吗、 I 等于1、L等于50 而却 I 还是在L的左边直接相减不进行了吗。
我当然也知道 IL 、但是在力扣刷题中 IL是个不成立的罗马字符
思路就是:
传入的字符串 如《IV》 前一位小于后一位就相减 结果等于:4,如果前一位大于后一位 如《VI》就相加 结果等于:6
function fun(num) {
// 使用ES6提供了Map数据结构
// set增加一个新元素,返回当前Map
// get返回键名对象的键值
const res = new Map();
res.set('I', 1);
res.set('V', 5);
res.set('X', 10);
res.set('L', 50);
res.set('C', 100);
res.set('D', 500);
res.set('M', 1000);
//初始化变量默认为0
let count = 0;
let n = num.length
//循环传入的字符串长度获取对应的健值
for(let i=0; i < n; i++){
const value = res.get(num[i])
//判断,当fun()中的字符串,循环时,前面的小于后面的就减减
//如 IV I代表1 V代表5 这个时候I<V 就减减 最后结果 4
//如 VX V代表5 X代表10 这个时候V<X 就减减 最后结果 5
//如 VI V代表5 I代表1 这个时候V>I 就加加 最后结果 6
//如 XV X代表10 V代表5 这个时候X>V 就加加 最后结果 15
//这个地方的判断就是用来比较前一项是否小于后一项,小于就减减 否者就 走else
if(res.get(num[i]) < res.get(num[i+1])){
count -= value
}else{
count += value
}
}
return count
}
console.log(fun('IV'))
// console.log(fun('VI'))