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)
相关推荐
跟着珅聪学java6 分钟前
编写高质量 CSS 样式完全指南
人工智能·python·tensorflow
进击的小头13 分钟前
第18篇:PID参数整定与裕度优化的现场调试实战
python·算法
cpp_250116 分钟前
P1796 汤姆斯的天堂梦
数据结构·c++·算法·题解·洛谷·线性dp
凌波粒21 分钟前
LeetCode--19.删除链表的倒数第 N 个结点(链表)
java·算法·leetcode·链表
飞Link1 小时前
LangChain 核心链式架构演进史:从顺序链到企业级路由兜底实战
python·架构·langchain
啥咕啦呛1 小时前
java打卡学习3:ArrayList扩容机制
java·python·学习
编程之升级打怪1 小时前
用排他锁来实现Python语言的变量值更新
开发语言·python
打乒乓球只会抽1 小时前
【无标题】
python
路小雨~1 小时前
Django 学习笔记:从入门到项目开发的完整梳理
笔记·python·学习·django
Yana.nice1 小时前
Ansible 常用模块
网络·python·ansible