js力扣每日一题(2022/4/16)

最大回文数乘积


给定一个整数 n ,返回 可表示为两个 n 位整数乘积的 最大回文整数 。因为答案可能非常大,所以返回它对 1337 取余 。

实例一:

输入:n = 2
输出:987
解释:99 x 91 = 9009, 9009 % 1337 = 987

示例二:

输入: n = 1
输出: 9

/**
 * @param {number} n
 * @return {number}
 */
var largestPalindrome = function(n) {
    if(n==1){
        return 9
    }
    let max = Math.pow(10,n)-1
    let min = Math.pow(10,n-1)
    for(let i = max;i>=min;i--) {
        let numbers = BigInt(i + String(i).split('').reverse().join(''))
        for(let j = BigInt(max) ; j*j >= numbers ; j--) {
            if(numbers % j === BigInt(0)) {
                return numbers % BigInt(1337)
            }
        }
    }
};

有一说一这道题就很烦,读完题很容易知道它要干什么,但是却存在无法下手的情况。
这道题两种做法,一种就是上述的代码(下方会细讲思路),第二种就是老六做法,直接列表去做,因为n的范围(1<=n<=8)
解题思路:
1.首先找出一种情况,那就是n=1时,它的结果只能是9(3*3 = 9)
2.我们需要找出n为不同值时,我们得到数的范围,这里就需要会一个方法,那就是Math.pow(a,b)(返回a的b次幂),通过这方法,我们很容易得到一个范围数
3.使用for循环,找出在min-max范围之间的一个数,并且通过数组、字符串方法使它转为一个回文数,(注:这里使用了一个数据类型BigInt,BigInt的存在是为了解决精度丢失的问题),在参考解析时,看到了大佬使用了BigInt,涉及到了知识盲区,我们想去拼接回文数,必须考虑到精度丢失
4.我们再进行for循环,找出合适的值,随后这个题就解决了

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端小白在前进

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值