难度:简单
给定一个整数 n ,返回 可表示为两个
n位整数乘积的 最大回文整数 。因为答案可能非常大,所以返回它对1337取余 。示例 1:
输入:n = 2 输出:987 解释:99 x 91 = 9009, 9009 % 1337 = 987示例 2:
输入:n = 1 输出:9提示:
1 <= n <= 8
题解:
pythonclass Solution: def largestPalindrome(self, n: int) -> int: if n == 1: return 9 # 1位数的最大回文数是9 # 生成 n 位数的最大值 max_num = int("9" *n) # 例如,n=3时,max_num = 999 min_num = 10 ** (n - 1) # n位数的最小值,即100 max_palindrome = 0 # 储存找到的最大回文数 # 从最大 n 位数开始逆序遍历 for i in range(max_num, min_num-1, -1): for j in range(i, min_num-1, -1): # j 从 i 开始,以减少重复计算 product = i * j # 检查乘积是否为回文 if str(product) == str(product)[::-1]: max_palindrome = max(max_palindrome, product) # 更新最大回文数 break # 找到的最大回文数可立即使用 return max_palindrome % 1337 # 返回结果对1337取余
leetcode:479. 最大回文数乘积(python3解法,数学相关算法题)
心软且酷丶2025-05-31 12:10
相关推荐
EntyIU1 分钟前
python开发中虚拟环境配置wszy18093 分钟前
顶部标题栏的设计与实现:让用户知道自己在哪乌萨奇也要立志学C++4 分钟前
【洛谷】递归初阶 三道经典递归算法题(汉诺塔 / 占卜 DIY/FBI 树)详解kaizq15 分钟前
AI-MCP-SQLite-SSE本地服务及CherryStudio便捷应用vyuvyucd22 分钟前
C++引用:高效编程的别名利器鱼跃鹰飞1 小时前
Leetcode1891:割绳子️停云️1 小时前
【滑动窗口与双指针】不定长滑动窗口码农小韩2 小时前
基于Linux的C++学习——指针!chen2 小时前
Error: error:0308010C:digital envelope routines::unsupporte小北方城市网2 小时前
分布式锁实战指南:从选型到落地,避开 90% 的坑