鱼C论坛

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

[已解决]编写一个函数,判断传入的字符串参数是否为“回文联”

[复制链接]
发表于 2022-10-7 23:40:10 | 显示全部楼层 |阅读模式

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

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

x
def palindrome(string):
    length = len(string)
    last = length-1
    length //= 2
    flag = 1
    for each in range(length):
        if string[each] != string[last]:  # 这一步为什么没有  string[each] == string[last]  
            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 分别返回哪一步啊 。。。没懂
最佳答案
2022-10-8 00:44:09
本帖最后由 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[each] != string[last]:  # each 是循环变量,也是头索引,last 是尾索引,string[each] 和 string[last] 是字符串首尾对称位置的两个字符,如果有任何一对字符不相等
            flag = 0                      # 那就否定之前所作 string 是回文联的假设,这里有点小问题,下一句应该是 break 语句,因为,结论已经被锁定,继续循环已经没有任何的意义。
        last -= 1                         # 尾部索引减 1,准备在下一次循环比较下一对字符,头部索引 each 数值的更新由循环驱动,不需要人为干预。

    if flag == 1:                         # 循环完成后,根据 flag 的值来判断是否是回文联,如果 flag 的值保持了 1
        return 1                          # 那么,说明前期的假设未曾在循环中被否定,函数返回 1
    else:                                 # 否则
        return 0                          # 说明前期的假设曾经在循环中被否定,函数返回 0

        来一个利用 string[each] == string[last] 作判断的版本
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[each] == string[last]:      # each 是头索引,last 是尾索引,如果 string[each] 和 string[last] 两个字符相等
            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:\[00.Exerciese.2022]\Python>python x.py
请输入一句话:上海自来水来自海上
是回文联!

D:\[00.Exerciese.2022]\Python>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-10-8 00:34:05 | 显示全部楼层
return 1 和 return 0 不是返回哪一步,而是函数palindrome(string)运行完返回一个值(0或1),由 if palindrome(string) == 1判断返回的值是不是1,如果是那就是回文联,否则不是回文联
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-10-8 00:44:09 | 显示全部楼层    本楼为最佳答案   
本帖最后由 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[each] != string[last]:  # each 是循环变量,也是头索引,last 是尾索引,string[each] 和 string[last] 是字符串首尾对称位置的两个字符,如果有任何一对字符不相等
            flag = 0                      # 那就否定之前所作 string 是回文联的假设,这里有点小问题,下一句应该是 break 语句,因为,结论已经被锁定,继续循环已经没有任何的意义。
        last -= 1                         # 尾部索引减 1,准备在下一次循环比较下一对字符,头部索引 each 数值的更新由循环驱动,不需要人为干预。

    if flag == 1:                         # 循环完成后,根据 flag 的值来判断是否是回文联,如果 flag 的值保持了 1
        return 1                          # 那么,说明前期的假设未曾在循环中被否定,函数返回 1
    else:                                 # 否则
        return 0                          # 说明前期的假设曾经在循环中被否定,函数返回 0

        来一个利用 string[each] == string[last] 作判断的版本
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[each] == string[last]:      # each 是头索引,last 是尾索引,如果 string[each] 和 string[last] 两个字符相等
            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:\[00.Exerciese.2022]\Python>python x.py
请输入一句话:上海自来水来自海上
是回文联!

D:\[00.Exerciese.2022]\Python>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-10-8 10:13:39 | 显示全部楼层
1 和 0 就相当于 True 和 False
如楼上所说 , 利用列表切片翻转列表是最最简单的方法
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-14 09:37

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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