温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2021-12-18 14:36:45 来源:亿速云 阅读:290 作者:iii 栏目:大数据

本篇内容介绍了“怎么用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大的值”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI