鱼C论坛

 找回密码
 立即注册
查看: 2018|回复: 2

[已解决]找了好久没找到问题点- -! 好无奈

[复制链接]
发表于 2017-5-14 20:17:36 | 显示全部楼层 |阅读模式

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

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

x
视频看到递归,然后用递归写了一个快速排序代码如下:  

  1. import random
  2. def quick_sort(li):
  3.     if len(li) < 2:
  4.         return li
  5.     else:
  6.         flag = random.choice(li)

  7.         lt = [i for i in li if i < flag]
  8.         gt = [i for i in li if i > flag]

  9.         return quick_sort(lt) + [flag] + quick_sort(gt)
复制代码


目前有个问题,排序倒是可以排序 但是如果 序列中有重复的 元素 将会被过滤掉如下图:
QQ截图20170514201135.png
然后我就修改以下代码:
  1. lt = [i for i in li if i <= flag]
复制代码

然后就。。。
QQ截图20170514201531.png

找了好久没找到问题点- -! 好无奈!!!
最佳答案
2017-5-14 21:14:11
按你修改的,如果flag是最大数,则li=lt,递归无限循环下去。
这样就可以了。
  1. import random
  2. def quick_sort(li):
  3.     if len(li) < 2:
  4.         return li
  5.     else:
  6.         flag = random.choice(li)

  7.         lt = [i for i in li if i < flag]
  8.         gt = [i for i in li if i > flag]
  9.         flag = [i for i in li if i == flag]

  10.         return quick_sort(lt) + flag + quick_sort(gt)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2017-5-14 21:14:11 | 显示全部楼层    本楼为最佳答案   
按你修改的,如果flag是最大数,则li=lt,递归无限循环下去。
这样就可以了。
  1. import random
  2. def quick_sort(li):
  3.     if len(li) < 2:
  4.         return li
  5.     else:
  6.         flag = random.choice(li)

  7.         lt = [i for i in li if i < flag]
  8.         gt = [i for i in li if i > flag]
  9.         flag = [i for i in li if i == flag]

  10.         return quick_sort(lt) + flag + quick_sort(gt)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-5-15 09:51:55 | 显示全部楼层
冬雪雪冬 发表于 2017-5-14 21:14
按你修改的,如果flag是最大数,则li=lt,递归无限循环下去。
这样就可以了。

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-27 12:38

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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