罗马数字转整数:

迷南。 2024-04-18 19:07 145阅读 0赞

罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。

字符     数值
I        1
V       5
X        10
L       50
C       100
D       500
M        1000

通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:

I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。
C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。

给定一个罗马数字,将其转换成整数。输入确保在 1 到 3999 的范围内。

列举可能:
①如果左边的罗马数字(srr[i])大于右边的罗马数字(srr[i+1]),结果是罗马数字相加,但是由于判断条件(i+1)会无法获取到最后一个,所以需要增加一个判断条件就是如果i==s.length-1;需要加上最后一个的值;
②如果左边的罗马数字小于右边的罗马数字,结果是右边的减去左边的,但是继续遍历的时候需要跳过下一个,例如下图遍历时需要跳过L。

  1. //定义一个函数使罗马数字转成整数
  2. var romanToInt = function (s) {
  3. var a = 0;//变量a用来保存转化的整数
  4. //obj对象里面保存了罗马数字及对应的值;
  5. var obj = {
  6. I: 1,
  7. V: 5,
  8. X: 10,
  9. L: 50,
  10. C: 100,
  11. D: 500,
  12. M: 1000
  13. }
  14. //for循环遍历传入的罗马数字,并且通过对象得到对应的整数值;
  15. for (var i = 0; i < s.length; i++) {
  16. //相加的话遍历不到最后一个的值需要加上;
  17. if (i == s.length - 1) {
  18. a = a +obj[s[s.length-1]];
  19. return a;
  20. }
  21. //判断是相加还是相减,相减的话是加上两数之和,所以遍历需要跳过一位;
  22. if (obj[s[i]] < obj[s[i + 1]]) {
  23. a = a + (obj[s[i + 1]] - obj[s[i]]);
  24. i++;//跳过一位
  25. } else {
  26. a += obj[s[i]];
  27. }
  28. }
  29. return a;
  30. };
  31. console.log(romanToInt('XLIV'))

发表评论

表情:
评论列表 (有 0 条评论,145人围观)

还没有评论,来说两句吧...

相关阅读