检查是否可以在Python中根据给定的N创建回文字符串
假设我们有一个数字n。我们必须检查是否可以从该数字创建字母小写字符串,并检查该字符串是否为回文。在这里,我们将只接受从a到j的字符,[a=0,b=1...j=9]。因此,如果数字为42,则将打印“ec”子字符串直到6(4+2)个字符“ececec”,然后检查是否为回文。
因此,如果输入像n=43,则输出将为True,字符串为“ededede”,这就是回文。
示例
让我们看下面的实现以更好地理解-
def isPalindrome(s):
return s == s[::-1]
def solve(n):
temp = ""
s = str(n)
letters = "abcdefghij"
sum = 0
substr = ""
for i in range(len(s)) :
d = int(s[i])
substr += letters[d]
sum += d
while len(temp) <= sum:
temp += substr
temp = temp[:sum]
return isPalindrome(temp)
n = 43
print (solve(n))输入值
43输出结果
True