Day63力扣打卡

打卡记录

寻找最近的回文数(模拟)

链接

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)
相关推荐
程序媛-徐师姐6 分钟前
基于 Python Django 的校园互助平台(附源码,文档)
开发语言·python·django·校园互助·校园互助平台
CoderIsArt7 分钟前
生成一个立方体贴图(Cube Map)
算法·sharpgl
且听风吟ayan13 分钟前
leetcode day20 滑动窗口209+904
算法·leetcode·c#
m0_6759882313 分钟前
Leetcode350:两个数组的交集 II
算法·leetcode·数组·哈希表·python3
_Itachi__14 分钟前
LeetCode 热题 100 160. 相交链表
算法·leetcode·链表
m0_6759882317 分钟前
Leetcode1206:设计跳表
算法·leetcode·跳表·python3
冠位观测者18 分钟前
【Leetcode 每日一题 - 扩展】1512. 好数对的数目
数据结构·算法·leetcode
Joyner201818 分钟前
python-leetcode-路径总和 III
算法·leetcode·职场和发展
南宫生19 分钟前
力扣每日一题【算法学习day.133】
java·学习·算法·leetcode
_Itachi__20 分钟前
LeetCode 热题 100 560. 和为 K 的子数组
数据结构·算法·leetcode