鱼C论坛

 找回密码
 立即注册
查看: 2595|回复: 3

[已解决]课后作业的答案有点看不懂,求大神帮忙解释一下

[复制链接]
发表于 2020-5-9 12:28:30 | 显示全部楼层 |阅读模式

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

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

x
  1. def palindrome(string):
  2.     length = len(string)
  3.     last = length-1
  4.     length //= 2
  5.     flag = 1
  6.     for each in range(length):
  7.         if string[each] != string[last]:
  8.             flag = 0
  9.         last -= 1

  10.     if flag == 1:
  11.         return 1
  12.     else:
  13.         return 0

  14. string = input('请输入一句话:')
  15. if palindrome(string) == 1:
  16.     print('是回文联!')
  17. else:
  18.     print('不是回文联!')
复制代码

有3个问题:
1. 在函数内为什么要定义一个 length-1 的变量
2. length 地板除是有什么作用吗?
3. 在之前的作业里面也看到过flag这个变量名称,想问问是不是有什么统一的习惯?flag = 1 是不是变相的True?
最佳答案
2020-5-9 13:00:16
1、定义last=length-1是为了在for循环中逐个比较,each是string的下标,从0开始,每次each会自加1,last则是从最后一个开始,每次减一,这里也可以定义last=-1
2、length地板除就是折半,第一位与最后一位比较,第二位与到时第二位比较……只需要比较到中间即可
3、经常用flag做为标记,是因为flag在英文中就是标志、旗帜的意思。具体flag赋什么值表达什么意思,由你定,这里完全可以反过来,甚至也完全可以不用flag
  1. def palindrome(string):
  2.     length = len(string)
  3.     last = -1
  4.     length //= 2
  5.     for each in range(length):
  6.         if string[each] != string[last]:
  7.             return 0
  8.         last -= 1
  9.     return 1

  10. string = input('请输入一句话:')
  11. if palindrome(string) == 1:
  12.     print('是回文联!')
  13. else:
  14.     print('不是回文联!')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-5-9 12:33:20 | 显示全部楼层
思路差不多是把字符串从中间分开,然后从两边比较,如果不一样则将flag设置为0.
这个flag就是一个旗子,如果为1,就代表立了起来,为0就代表放倒了。
你还可以:
  1. return string == string[::-1]
复制代码

一行代码解决
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-9 13:00:16 | 显示全部楼层    本楼为最佳答案   
1、定义last=length-1是为了在for循环中逐个比较,each是string的下标,从0开始,每次each会自加1,last则是从最后一个开始,每次减一,这里也可以定义last=-1
2、length地板除就是折半,第一位与最后一位比较,第二位与到时第二位比较……只需要比较到中间即可
3、经常用flag做为标记,是因为flag在英文中就是标志、旗帜的意思。具体flag赋什么值表达什么意思,由你定,这里完全可以反过来,甚至也完全可以不用flag
  1. def palindrome(string):
  2.     length = len(string)
  3.     last = -1
  4.     length //= 2
  5.     for each in range(length):
  6.         if string[each] != string[last]:
  7.             return 0
  8.         last -= 1
  9.     return 1

  10. string = input('请输入一句话:')
  11. if palindrome(string) == 1:
  12.     print('是回文联!')
  13. else:
  14.     print('不是回文联!')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-9 13:23:11 | 显示全部楼层
qiuyouzhi 发表于 2020-5-9 12:33
思路差不多是把字符串从中间分开,然后从两边比较,如果不一样则将flag设置为0.
这个flag就是一个旗子,如 ...

感谢感谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-30 05:12

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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