鱼C论坛

 找回密码
 立即注册
查看: 2095|回复: 4

[已解决]课后作业回文联

[复制链接]
发表于 2019-11-18 20:00:13 | 显示全部楼层 |阅读模式

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

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

x
def judgehui(hui):
    length = len(hui)
    a = len(hui)-1;b = 0;count = 0;x = len(hui)//2
    if length % 2 ==0:
        while x > 0:
            if hui[a] == hui[b]:
                count += 1
                x -= 1
    else:
         while int(x) > 0:
             if hui[a] == hui[b]:
                 count += 1
                 x -= 1
    if count == int(x):
        print('是回文联!')
    else:
        print('不是回文联!')
hui = input('请输入一句话:')
judgehui(hui)
我的代码永远不是回文联,请问哪里错了呢
最佳答案
2019-11-18 20:30:22
本帖最后由 jackz007 于 2019-11-18 20:42 编辑

       看不懂楼主的思路,于是就自己写了一遍,有一点可以肯定,每次比较字符串中的 2 个字符,所以,循环次数只需 length 的一半。
def judgehui(hui):
    f  , length = True , len(hui)
    for i in range(length // 2) :
        if hui[i] != hui[length - i - 1]:
            f = False
            break
    return f

if judgehui(input('请输入一句话:') . strip()) :
    print('是回文联!')
else:
    print('不是回文联!')
        当然,这么写更简单:
hui = input('请输入一句话:') . strip()
if hui == hui[:: -1]:
    print('是回文联!')
else:
    print('不是回文联!')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-11-18 20:30:22 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2019-11-18 20:42 编辑

       看不懂楼主的思路,于是就自己写了一遍,有一点可以肯定,每次比较字符串中的 2 个字符,所以,循环次数只需 length 的一半。
def judgehui(hui):
    f  , length = True , len(hui)
    for i in range(length // 2) :
        if hui[i] != hui[length - i - 1]:
            f = False
            break
    return f

if judgehui(input('请输入一句话:') . strip()) :
    print('是回文联!')
else:
    print('不是回文联!')
        当然,这么写更简单:
hui = input('请输入一句话:') . strip()
if hui == hui[:: -1]:
    print('是回文联!')
else:
    print('不是回文联!')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-18 20:39:28 | 显示全部楼层
代码写的太复杂,其实只要两三行代码就搞定:
def judgehui(s):
    if s == s[::-1]:
        print('是回文联!')
    else:
        print('不是回文联!')


hui = input('请输入一句话:')
judgehui(hui)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-11-19 20:23:38 | 显示全部楼层
jackz007 发表于 2019-11-18 20:30
看不懂楼主的思路,于是就自己写了一遍,有一点可以肯定,每次比较字符串中的 2 个字符,所以,循环 ...

hui[:: -1]是啥意思呢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-19 20:35:44 | 显示全部楼层
本帖最后由 jackz007 于 2019-11-19 20:37 编辑
yooooly 发表于 2019-11-19 20:23
hui[:: -1]是啥意思呢


      就是把可迭代对象逆序排列,对于字符串而言,就是把它首尾颠倒,例如,hui = 'ABCDEFG',那么,hui[:: -1] = 'GFEDCBA'。楼主自己也可以在 IDLE 环境中测试一下效果。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-12 20:09

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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