鱼C论坛

 找回密码
 立即注册
查看: 838|回复: 1

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

[复制链接]
发表于 2024-1-10 15:53:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
编写一个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)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 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 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-22 23:19

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表