leetcode 算法题800 (简单208) 相似 RGB 颜色

leetcode 算法题800 (简单208) 相似 RGB 颜色

  • 题目介绍
RGB 颜色用十六进制来表示的话,
每个大写字母都代表了某个从 0 到 f 的 16 进制数。
RGB 颜色 "#AABBCC" 可以简写成 "#ABC" 。
例如,"#15c" 其实是 "#1155cc" 的简写。

现在,假如我们分别定义两个颜色 "#ABCDEF" 和 "#UVWXYZ",则他们的相似度可以通过这个表达式 -(AB - UV)^2 - (CD - WX)^2 - (EF - YZ)^2 来计算。

那么给定颜色 "#ABCDEF",请你返回一个与 #ABCDEF 最相似的 7 个字符代表的颜色,并且它是可以被简写形式表达的。(比如,可以表示成类似 "#XYZ" 的形式)

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/similar-rgb-color
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
  • 示例

输入:color = “#09f166”
输出:"#11ee66"
解释:因为相似度计算得出 -(0x09 - 0x11)^2 -(0xf1 - 0xee)^2 - (0x66 - 0x66)^2 = -64 -9 -0 = -73
这已经是所有可以简写的颜色中最相似的了

  • 注意

color 是一个长度为 7 的字符串
color 是一个有效的 RGB 颜色:对于仍和 i > 0,color[i] 都是一个在 0 到 f 范围的 16 进制数
假如答案具有相同的(最大)相似度的话,都是可以被接受的
所有输入、输出都必须使用小写字母,并且输出为 7 个字符

  • 解法一
/**
 * @param {string} color
 * @return {string}
 */
var similarRGB = function(color) {
  let a = getSimilar(color[1], color[2]), b = getSimilar(color[3], color[4]), c = getSimilar(color[5], color[6]);
    return "#" + a + a + b + b + c + c;
};

const getSimilar = (a, b) => {
  let x = parseInt(a, 16) - parseInt(b, 16);
  if(x > 8) {
    return (parseInt(a, 16) - 1).toString(16);
  } 
  if(x < -8) {
    return (parseInt(a, 16) + 1).toString(16);
  }
  return a;
}

执行用时 : 64 ms, 在所有 JavaScript 提交中击败了%50.00的用户

内存消耗 : 33.6 MB, 在所有 JavaScript 提交中击败了100.00%的用户

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值