是肥宅SRP啊 发表于 2024-1-10 15:53:55

打印出使字符串成为回文所需的最小字符数

编写一个Python程序,打印出使字符串成为回文所需的最小字符数。
要求:只能在字符串末尾添加字符,让字符串成为回文。


下面的代码不对,当输入的字符串为joo时它返回的是2,但是其实应该是1才对,只需要添加j,请问我应该如何改善下列代码?
# 定义需要成为回文的字符串
# 和计数器来表示需要添加多少个字母才能使字符串成为回文
string = input()

counter = 0

# 循环直到字符串的长度大于0
while len(string)>0:

    # 如果字符串是回文,那么就跳出循环
    if string == string[::-1]:
         break

    # 否则,计数器加一,并从字符串中删除最后一个字母
    else:
      string = string[:-1]
      counter += 1


# 打印计数器变量
print(counter)

FishC 发表于 2024-1-10 15:54:36

问题出在判断字符串是否为回文的条件上。目前的代码中,判断条件`if string == string:`是没有意义的,因为一个字符串始终等于它自己。

要判断一个字符串是否为回文,可以将其与逆序的字符串进行比较。如果两个字符串相等,则原字符串是回文。

下面是修改后的代码:

# 定义需要成为回文的字符串
# 和计数器来表示需要添加多少个字母才能使字符串成为回文
string = input()

counter = 0

# 循环直到字符串是回文
while string != string[::-1]:
    # 在字符串末尾添加一个字符
    string += string[-1]
    # 计数器加一
    counter += 1

# 打印计数器变量
print(counter)

现在,代码会重复执行两个操作直到字符串成为回文:
1. 在字符串末尾添加一个字符,通过`string += string[-1]`来实现。
2. 计数器加一。

同时,我们使用切片操作`string[::-1]`来获取字符串的逆序,然后与原字符串进行比较,判断是否为回文。

运行代码后,输入`joo`,输出为`1`,符合预期结果。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
页: [1]
查看完整版本: 打印出使字符串成为回文所需的最小字符数