LeetCode-564 寻找最近的回文数
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/find-the-closest-palindrome
题目描述
给定一个表示整数的字符串 n ,返回与它最近的回文整数(不包括自身)。如果不止一个,返回较小的那个。
“最近的”定义为两个整数差的绝对值最小。
示例 1:
输入: n = "123"
输出: "121"
示例 2:
输入: n = "1"
输出: "0"
解释: 0 和 2是最近的回文,但我们返回最小的,也就是 0。
提示:
1 <= n.length <= 18
n 只由数字组成
n 不含前导 0
n 代表在 [1, 1018 - 1] 范围内的整数
解题思路
一道十分困难的脑经急转弯题。。
关键要想到,每次将字符串前半部分镜像到后半部分得到的数字比将后半部分复制到前半部分构成的字符串更加接近原数。
所以可以确定候选的一些数字分别是由前半部分数字多1,前半部分数字,前半部分数字减1,999……999, 100……001之中。
将这五个数枚举出来,依次判断出非本身外最接近原数的数即可。
代码展示
class Solution { public: string nearestPalindromic(string n) { int iN = n.size(); long lSelf = stol(n); vector<long> vlN = {(long)pow(10, iN - 1) - 1, (long)pow(10, iN) + 1}; string strPrefix = n.substr(0, (iN + 1) / 2); long lPrefix = stol(strPrefix); for(long i: {lPrefix - 1, lPrefix, lPrefix + 1}) { string strTemp = to_string(i); string strCandidate = strTemp + string(strTemp.rbegin() + (iN & 1), strTemp.rend()); vlN.push_back(stol(strCandidate)); } long lRet = -1; for(auto iter: vlN) { if(iter != lSelf) { if(abs(lSelf - iter) < abs(lSelf - lRet) || abs(lSelf - iter) == abs(lSelf - lRet) && iter < lRet) { lRet = iter; } } } return to_string(lRet); } };
运行结果
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了