鱼C论坛

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

[已解决]判断回文联那题

[复制链接]
发表于 2020-3-11 19:59:19 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 大珠提子 于 2020-3-11 20:08 编辑

我写的答案:
def wen():
    for i in range (0, l-1):
        if g[i] == g[l-1-i]:
            print('是回文联')
        else:
            print('不是回文联')

g = input("请输入一句话:")
l = len(g)
wen()
这个问题是因为for循环,结果会打很多次,可以优化吗?
最佳答案
2020-3-11 20:06:24
这代码不只这一个问题吧。
  if g[i] == g[l-1-i]:
            print('是回文联')
这样就是回文了???? 字符串都没有比效完就是了?
def wen():
    flag = False
    for i in range (0, l-1):
        if g[i] != g[l-1-i]:
            break
        flag = True
        
    if flag:
        print('是回文联') 
    
    else:
        print('不是回文联')
        

g = input("请输入一句话:")
l = len(g)
wen()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

头像被屏蔽
 楼主| 发表于 2020-3-11 20:02:13 | 显示全部楼层
提示: 该帖被管理员或版主屏蔽
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-3-11 20:06:24 | 显示全部楼层    本楼为最佳答案   
这代码不只这一个问题吧。
  if g[i] == g[l-1-i]:
            print('是回文联')
这样就是回文了???? 字符串都没有比效完就是了?
def wen():
    flag = False
    for i in range (0, l-1):
        if g[i] != g[l-1-i]:
            break
        flag = True
        
    if flag:
        print('是回文联') 
    
    else:
        print('不是回文联')
        

g = input("请输入一句话:")
l = len(g)
wen()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2020-3-11 20:12:00 | 显示全部楼层
ba21 发表于 2020-3-11 20:06
这代码不只这一个问题吧。
  if g == g[l-1-i]:
            print('是回文联')

谢谢修改,问题没看懂,用for可以一次性比较完吧?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-27 16:33:27 | 显示全部楼层
大珠提子 发表于 2020-3-11 20:12
谢谢修改,问题没看懂,用for可以一次性比较完吧?

会打很多次就是因为比较一次首和尾,若相同,就打印一次
不相同就继续比较,所以说没有比较完就执行了if下的那个打印
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-25 13:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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