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

LeetCode 479. 最大回文数乘积题解,第1张

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}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/674075.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-19
下一篇 2022-04-19

发表评论

登录后才能评论

评论列表(0条)

保存