编写一个函数,判断传入的字符串参数是否为“回文联”
def palindrome(string):length = len(string)
last = length-1
length //= 2
flag = 1
for each in range(length):
if string != string:# 这一步为什么没有string == string
flag = 0
last -= 1
if flag == 1:
return 1
else:
return 0
string = input('请输入一句话:')
if palindrome(string) == 1:
print('是回文联!')
else:
print('不是回文联!')
return 1和 return 0 分别返回哪一步啊 。。。没懂
return 1 和 return 0 不是返回哪一步,而是函数palindrome(string)运行完返回一个值(0或1),由 if palindrome(string) == 1判断返回的值是不是1,如果是那就是回文联,否则不是回文联 本帖最后由 jackz007 于 2022-10-8 08:59 编辑
def palindrome(string):
length = len(string) # length = 字符串 string 的长度
last = length - 1 # 字符串 string 尾部索引变量 last 指向字符串的最后一个字符
length //= 2 # length = 字符串长度的一半
flag = 1 # flag = 1,先假定 string 是回文联
for each in range(length): # 以 each 为索引,在 0 ~ len(string) // 2 的范围内,对字符串首尾对称位置的字符对进行比较
if string != string:# each 是循环变量,也是头索引,last 是尾索引,string 和 string 是字符串首尾对称位置的两个字符,如果有任何一对字符不相等
flag = 0 # 那就否定之前所作 string 是回文联的假设,这里有点小问题,下一句应该是 break 语句,因为,结论已经被锁定,继续循环已经没有任何的意义。
last -= 1 # 尾部索引减 1,准备在下一次循环比较下一对字符,头部索引 each 数值的更新由循环驱动,不需要人为干预。
if flag == 1: # 循环完成后,根据 flag 的值来判断是否是回文联,如果 flag 的值保持了 1
return 1 # 那么,说明前期的假设未曾在循环中被否定,函数返回 1
else: # 否则
return 0 # 说明前期的假设曾经在循环中被否定,函数返回 0
来一个利用 string == string 作判断的版本
def palindrome(string):
c = 0 # 计数器置 0
last = len(string) - 1 # 字符串 string 尾部索引变量 last 指向字符串的最后一个字符
for each in range(len(string) // 2): # 以 each 为索引,在 0 ~ len(string) // 2 - 1 的范围内,对字符串首尾对称位置的字符对进行比较
if string == string: # each 是头索引,last 是尾索引,如果 string 和 string 两个字符相等
c += 1 # 计数器值加 1
last -= 1 # 尾索引 last 值减 1
return c == len(string) // 2 # 如果循环过程中的每一对字符都相同,那么,c == len(string) // 2 就是 True,否则,当然是 False 了。
string = input('请输入一句话:') . strip()
if palindrome(string) :
print('是回文联!')
else:
print('不是回文联!')
最简单的版本:
def palindrome(string):
return string == string[::-1]
string = input('请输入一句话:') . strip()
print('是回文联!') if palindrome(string) else print('不是回文联!')
运行实况:
D:\\Python>python x.py
请输入一句话:上海自来水来自海上
是回文联!
D:\\Python> 1 和 0 就相当于 True 和 False
如楼上所说 , 利用列表切片翻转列表是最最简单的方法
页:
[1]