千家信息网

怎么用Python找出list第2大的值

发表于:2024-09-24 作者:千家信息网编辑
千家信息网最后更新 2024年09月24日,本篇内容介绍了"怎么用Python找出list第2大的值"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成
千家信息网最后更新 2024年09月24日怎么用Python找出list第2大的值

本篇内容介绍了"怎么用Python找出list第2大的值"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

题目:现有一个lst,无重复数据,其内容为:

lst = [1,4,2,77,24,57,42]

这一次不是让你找出最大值,而是找出第2大的值,要求只能对list遍历一次,而且lst中的元素的大小范围是不确定的。


题目解析
  • 只能遍历一次list,这就意味着不能先排序,因为排序过程遍历了不止一次

  • 要找的是第2大的值


回顾找最大值的的方法

lst = [1,4,2,77,24,57,42]
max = lst[0]
for item in lst:
if item > max:
max = item

print max

找最大值,先定义了一个max,令其值为lst[0],遍历的过程中逐个比较,那么找第2大的值和不在此基础上进行呢。

定义一个second,也令其值为lst[0],在遍历过程中也逐个比较,如果item比second大,同时又比max小不就可以了么!


示例代码

lst = [1,4,2,77,24,57,42]
max = lst[0]
second = lst[0]

for item in lst:
if item > max:
max = item

if item > second and item < max:
second = item

print max,second

程序的输出结果为 77 57 ,程序关键之处在于比较item和second的大小时,也考虑到了max的情况,这样很简单嘛,一点都不烧脑,???? 不烧脑,我怎么敢拿出来呢!

请考虑这种情况:

lst = [77,4,2,24,57,42]

lst[0] 本身就是最大值,上面的代码还能给出正确的结果么?不能,程序运行的结果是 77 77 ,剧情翻转了,由于lst[0]是最大值,导致两个if条件语句都不成立,现在感觉到烧脑了么?

之所以程序不能给出正确结果,皆因max 和 second在最初赋值的时候相等,这是问题的根源,那么只需要让second的初始值比max小便能解决这个问题


示例代码

lst = [77,1,4,2,24,57,42]
max = lst[0]
if lst[0] > lst[1]:
second = lst[1]
else:
second = lst[0]

for item in lst:
if item > max:
max = item

if item > second and item < max:
second = item

print max,second

"怎么用Python找出list第2大的值"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

0