python判断是否可以只插一个字符,让字符串变成回文,返回true/false

2021/6/29 11:24:40

本文主要是介绍python判断是否可以只插一个字符,让字符串变成回文,返回true/false,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

这个需要考虑几种情况:

  1. 1 2 3 4 5 3 2 1 可以
  2. 1 2 4 3 5 3 2 1 可以
  3. 1 2 4 3 3 5 2 1 不可以
  4. 1 2 3 4 4 3 2 1 可以
  5. 1 2 3 5 3 2 1 可以
  6. 1 2 4 5 3 2 1 不可以
  7. 1 2 4 4 3 2 1 可以
  8. 1 3 4 4 3 2 1 可以

或者用土办法想 ,插入数有俩个纬度,1,单数会变成偶数,偶数会变成单数
2,插入的位置 只有左半部,中间,右半部
所以要让填完之后的字符串变成回文,也就是左右相等。
所以从头开始比对,发现不一样的,就insert。然后判断是不是回文就可以了

所以我们的函数内可以这么写:

def panduan(str1):
    from copy import deepcopy
    li = list(str1)
    state = False
    if li == li[::-1]:
        state = True
    else:
        for i in range(len(li)/2):
            if li[i] != li[-1-i]:
                liA = deepcopy(li)
                liA.insert(i, li[-1 - i])
                liB = deepcopy(li)
                liB.insert(-i,li[i])
                if liA == liA[::-1]:
                    print 'liA:',''.join(liA)
                    state = True
                if liB == liB[::-1]:
                    print 'liB:',''.join(liB)
                    state = True
    return state

print panduan("12345421")

 



这篇关于python判断是否可以只插一个字符,让字符串变成回文,返回true/false的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程