LeetCode 479. 最大回文数乘积题解

479. 最大回文数乘积题解

题目来源:479. 最大回文数乘积

2022.04.16 每日一题

LeetCode 题解持续更新中GitHub仓库地址 CSDN博客地址

今天的题目思路比较简单,我个人认为难点在于回文数字的构造之上,我们可以通过从大到小搜索回文数字,然后判断这个回文数字能否由两个 n 位整数相乘得到

这样我们就把问题分解成为两部分

  • 寻找回文数字
  • 判断回文数字是否由两个 n 位整数相乘得到

首先先处理简单的,判断回文数字能否由 两个 n 位数字相乘得到

我们可以将回文数开方,得到数字 s ,从 s 到 pow(10,n) 之间来寻找有没有一个数字是 此回文数的因数,如果存在,就说明这个回文数是满足我们的要求的,不存在就说明,这个回文数不是我们所要求的。

然后就是关于如何构造一个回文数字

我们根据题意可以知道,我们回文数字是由 2 个 n 位数字相乘得到,因此最多也不会超过 2*n 位数字,由此,我们可以首先确定回文数的左半部分即 n 位数字,而后再翻转,得到右半部分的数字,就组合成了一个回文数字

class Solution {
public:
    int largestPalindrome(int n) {
        // 如果 n 等于 1 直接返回 9 就行
        if (n == 1) return 9;
        // 取得 n 位数字的最大值
        int ll = pow(10, n) - 1;
        // 从最大值开始构造回文数字
        for (int l = ll;; l--) {
            // 创建回文数字变量 h ,
            // 使用 long 定义是因为会 超出 int 的范围
            long h = l;
            // 将 数字左侧的数字,逐步添加到 h 的后面
            for (int q = l; q > 0; q /= 10) h = h * 10 + q % 10;
            // 从 n 位数字的最大值开始寻找 回文数的因数
            // 如果两个的数字的乘积小于了 当前的回文数字,
            // 说明以及查找到的数字的后面的数字也不会整除此回文数
            for (long q = ll; q * q >= h; q--)
                // 如果发现了 可以整除的 数字,直接进行返回即可
                if (h % q == 0) return (int) (h % 1337);
        }
    }
};
class Solution {
    public int largestPalindrome(int n) {
        // 如果 n 等于 1 直接返回 9 就行
        if (n == 1) return 9;
        // 取得 n 位数字的最大值
        int ll = (int) Math.pow(10, n) - 1;
        // 从最大值开始构造回文数字
        for (int l = ll; ; l--) {
            // 创建回文数字变量 h ,
            // 使用 long 定义是因为会 超出 int 的范围
            long h = l;
            // 将 数字左侧的数字,逐步添加到 h 的后面
            for (int q = l; q > 0; q /= 10) h = h * 10 + q % 10;
            // 从 n 位数字的最大值开始寻找 回文数的因数
            // 如果两个的数字的乘积小于了 当前的回文数字,
            // 说明以及查找到的数字的后面的数字也不会整除此回文数
            for (long q = ll; q * q >= h; q--)
                // 如果发现了 可以整除的 数字,直接进行返回即可
                if (h % q == 0) return (int) (h % 1337);
        }
    }
}

常规方法说完了以后就来点不常规的 手动狗头

{9, 987, 123, 597, 677, 1218, 877, 475}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值