鱼C论坛

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

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

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

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

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

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


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

  4. counter = 0

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

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

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


  14. # 打印计数器变量
  15. print(counter)
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-1-10 15:54:36 | 显示全部楼层
问题出在判断字符串是否为回文的条件上。目前的代码中,判断条件`if string == string:`是没有意义的,因为一个字符串始终等于它自己。

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

下面是修改后的代码:

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

  4. counter = 0

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

  11. # 打印计数器变量
  12. print(counter)
复制代码


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

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

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

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-20 14:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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