zoukankan      html  css  js  c++  java
  • 【leetcode】564. Find the Closest Palindrome

    题目如下:

    解题思路:既然是要求回文字符串,那么最终的输出结果就是对称的。要变成对称字符串,只要把处于对称位置上对应的两个字符中较大的那个变成较小的那个即可,假设n=1234,1和4对称所以把4变成1,2和3对称把3变成2,得到1221,看起来好像没问题了。可是如果n=1283,按照这个方法得到的结果是1221,而预期的结果应该是1331,所以需要考虑到进位和退位的问题。这就有点复杂了,简单点的方法也有,就是把进位和退位的所有情况都列举出来再做比较,得出差值最小的那个。例如n=1283,按照对称法则得到的结果是1221,再把处于最中间的两个字符22分别进位和退位就可以得到1331和1111。接下来考虑到数量级的进位退位,对于一个四位数的n来说,与其最接近的三位数长度的回文数是999,最接近的五位数长度是10001。所以最后在这五个数字中得出符合题目要求的答案。

    代码如下:

    class Solution(object):
        def nearestPalindromic(self, n):
            """
            :type n: str
            :rtype: str
            """
            l = list(n)
            low = 0
            high = len(l) - 1
            while low <= high:
                if l[low] != l[high]:
                    l[high] = l[low]
                low += 1
                high -= 1
    
            candidateList = ['1' + '0'*(len(n)-1) + '1','9' * (len(n) - 1),''.join(l)]
            mid = len(l) / 2
            if len(l) % 2 == 0:
                if l[mid] == '0':
                    candidateList.append(''.join(l[0:mid - 1] + ['1'] * 2 + l[mid + 1:]))
                elif l[mid] == 9:
                    candidateList.append(''.join(l[0:mid - 1] + ['8'] * 2 + l[mid + 1:]))
                else:
                    candidateList.append(''.join(l[0:mid - 1] + [str(int(l[mid]) - 1)] * 2 + l[mid + 1:]))
                    candidateList.append(''.join(l[0:mid - 1] + [str(int(l[mid]) + 1)] * 2 + l[mid + 1:]))
            else:
                if l[mid] == '0':
                    candidateList.append(''.join(l[0:mid] + ['1'] * 1 + l[mid + 1:]))
                elif l[mid] == 9:
                    candidateList.append(''.join(l[0:mid] + ['8'] * 1 + l[mid + 1:]))
                else:
                    candidateList.append(''.join(l[0:mid] + [str(int(l[mid]) - 1)] * 1 + l[mid + 1:]))
                    candidateList.append(''.join(l[0:mid] + [str(int(l[mid]) + 1)] * 1 + l[mid + 1:]))
    
            res = ''
            mDiff = 0
            for i in candidateList:
                if i == n or i == '':
                    continue
                diff = abs(int(n) - int(i))
                if mDiff == 0 or mDiff > diff:
                    res = i
                    mDiff = diff
                elif mDiff == diff:
                    res = str(min(int(res), int(i)))
    
            return res
  • 相关阅读:
    Linux关闭防火墙命令
    js改变数组的两个元素的位子,互换、置顶
    vue nexttick的理解和使用场景
    vue mint-ui 框架下拉刷新上拉加载组件的使用
    vue项目中使用了vw适配方案,引入第三方ui框架mint-ui时,适配问题解决
    小程序开发笔记【二】,抽奖结果json数据拼装bug解决
    gulp插件gulp-nunjucks-render的使用及gulp4的简单了解
    小程序开发笔记【一】,查询用户参与活动列表 left join on的用法
    mysql数据插入前判断是否存在
    微信公众号通过图片选取接口上传到阿里oss
  • 原文地址:https://www.cnblogs.com/seyjs/p/9585935.html
Copyright © 2011-2022 走看看