12 整数转罗马数字(2021-07-07)

11. 盛最多水的容器

链接:https://leetcode-cn.com/problems/integer-to-roman/

题目描述见链接内容。

解法1:高级API

利用了JS的很多高级API,思路就是先把数字按照个位、十位、百位、千位拆成一个数组,然后倒序,从个位开始,通过配置区分区情况,然后再重新组合起来

var intToRoman = function (num) {
  const DICT = {
    0: {1: 'I', 5: 'V', 10: 'X'},
    1: {1: 'X', 5: 'L', 10: 'C'},
    2: {1: 'C', 5: 'D', 10: 'M'},
    3: {1: 'M'}
  };

  return num
    .toString()
    .split('')
    .reverse()
    .map((v, index) => {
      return toRoman(+v, DICT[index]);
    })
    .reverse()
    .join('');
};

function toRoman(num, conf) {
  if (num === 0) {
    return '';
  }
  if (num === 9) {
    return conf[1] + conf[10];
  }
  if (num === 4) {
    return conf[1] + conf[5];
  }
  if (num >= 5) {
    return conf[5] + conf[1].repeat(num - 5);
  }
  return conf[1].repeat(num);
}

执行用时:132ms, 在所有JavaScript提交中击败了100%的用户,内存消耗:45.6MB,在所有JavaScript提交中击败了13%用户

解法2:模拟法

还是官方题解给出的解法更简单,给出一个配置,数字总是去匹配配置中最大的那一个,然后用配置中的数字去缩小给定的数字,直到结束

var intToRoman = function (num) {
  const DICT = [
    [1000, 'M'],
    [900, 'CM'],
    [500, 'D'],
    [400, 'CD'],
    [100, 'C'],
    [90, 'XC'],
    [50, 'L'],
    [40, 'XL'],
    [10, 'X'],
    [9, 'IX'],
    [5, 'V'],
    [4, 'IV'],
    [1, 'I']
  ];
  let result = '';

  for (const [val, str] of DICT) {
    while (num >= val) {
      num -= val;
      result += str;
    }
  }
  return result;
};
  • 执行用时:128ms, 在所有JavaScript提交中击败了99.88%的用户,内存消耗:43.5MB,在所有JavaScript提交中击败了82.81%的用户
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值