Python | Leetcode Python题解之第564题寻找最近的回文数

题目:

题解:

python 复制代码
class Solution:
    def nearestPalindromic(self, n: str) -> str:
        m = len(n)
        candidates = [10 ** (m - 1) - 1, 10 ** m + 1]
        selfPrefix = int(n[:(m + 1) // 2])
        for x in range(selfPrefix - 1, selfPrefix + 2):
            y = x if m % 2 == 0 else x // 10
            while y:
                x = x * 10 + y % 10
                y //= 10
            candidates.append(x)

        ans = -1
        selfNumber = int(n)
        for candidate in candidates:
            if candidate != selfNumber:
                if ans == -1 or \
                        abs(candidate - selfNumber) < abs(ans - selfNumber) or \
                        abs(candidate - selfNumber) == abs(ans - selfNumber) and candidate < ans:
                    ans = candidate
        return str(ans)
相关推荐
源码之家几秒前
计算机毕业设计:基于Python的汽车数据可视化分析系统 Django框架 Scrapy爬虫 可视化 车辆 懂车帝大数据 数据分析 机器学习(建议收藏)✅
python·信息可视化·django·flask·汽车·课程设计·美食
我的xiaodoujiao1 分钟前
API 接口自动化测试详细图文教程学习系列8--测试接口
python·学习·测试工具·pytest
羊小猪~~2 分钟前
算法/力扣--字符串经典题目
c++·考研·算法·leetcode·职场和发展·哈希算法
蓝色的杯子7 分钟前
免费体验GPT5.4效果
python·chatgpt
逐渐会飞8 分钟前
如何用python在word插入复选框
python·word
Yao.Li8 分钟前
Dify 本地运行实操笔记
人工智能·笔记·python
Yao.Li13 分钟前
Dify 请求主链路梳理
人工智能·python
Thomas.Sir14 分钟前
第十二章:Prompt 提示工程 之 实战项目
python·prompt
人道领域14 分钟前
LeetCode【刷题日记】:数组篇(1)含原理讲解
算法·leetcode·职场和发展
第一程序员19 分钟前
Python自动化办公:提升工作效率的利器
python·github