广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python列表与列表算法详解(2)
  • 513
分享到

python列表与列表算法详解(2)

2024-04-02 19:04:59 513人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录2. 案例【三酷猫冒泡法排序】3. 案例【三酷猫二分法查找】总结1. 案例【三酷猫列表记账】 操作需求: (1)用列表对象记录三酷猫每天钓鱼的种类和数量 (2)统计三酷猫所钓

1. 案例【三酷猫列表记账】

操作需求:

(1)用列表对象记录三酷猫每天钓鱼的种类和数量

(2)统计三酷猫所钓水产品的总数量和预计收获金额

(3)打印财务报表一张。

在这里插入图片描述


#三酷猫列表记账
nums = 0              #统计数量变量
amount = 0              #统计金额数量
i = 0                   #循环控制变量
fish_record = ['1月1日','鲫鱼',18,10.5,'1月1日','鲤鱼',8,6.2,'1月1日','鲢鱼',7,4.7,'1月2日','草鱼',2,7.2,'1月2日','鲫鱼',3,12,'1月2日','黑鱼',6,15,'1月3日','乌龟',1,71,'1月3日','鲫鱼',1,9.8]
print('钓鱼日期名称数量单价(元)')
print('-'*30)
while i<len(fish_record):
    nums = nums + fish_record[i+2]      #累计数量
    amount = amount + fish_record[i+2]*fish_record[i+3]   #累计金额
    print('%s,%s,%.2f,%.2f'%(fish_record[i],fish_record[i+1],fish_record[i+2],fish_record[i+3]))
    i += 4                  #循环控制
print('-'*30)
print('        总数:%d,总金额%.2f元'%(nums,amount))

结果:

在这里插入图片描述

2. 案例【三酷猫冒泡法排序】

冒泡排序:通过不断调整排序元素的次序,实现集合元素从小到大的排序过程。

** 冒泡排序过程**

(1)取左边第一个元素,然后与后面的元素进行比较,若发现后面的元素比第一个元素小,则交换位置,继续往后比较,一直比较调整到最后一个元素,该元素为最大的元素。

(2)再取第一个元素,根据第一步一次比较、调整,直到倒数第二个停止;其他元素都依次循环比较、调整,每次循环多减一次,n-m(n为集合长度,m为每循环一次,增加一次,m从0 开始)。

(3)所有元素比较、调整完毕,完成集合元素增序排序。

冒泡法排序示意图

在这里插入图片描述


fish_records = [18,8,7,2,3,6,1,1]
i = 0                               #循环控制变量
compare = 0                         #比较元素初始值
fish_len = len(fish_records)        #获取列表长度
while i<fish_len:
    j = 1                           #循环控制变量
    while j<fish_len-i:             #循环一遍,长度减1
        if fish_records[j-1]>fish_records[j]:   #比较前后两个元素的大小
            compare = fish_records[j-1]         #前一个大的放到临时比较变量里
            fish_records[j-1] = fish_records[j] #把小的元素放到前面
            fish_records[j] = compare           #把临时变量里的大元素放到后面
        j += 1                      #内循环控制变量+1
    i += 1                          #外循环控制变量+1
print(fish_records)

结果:

在这里插入图片描述

3. 案例【三酷猫二分法查找】

二分法查找:指在有序集合里,对集合下标范围通过取中位法获取对应的元素值,进行叠代查找比较,直至找到所需要的元素。如set1[1…N],(1…N为集合元素下标顺序值)先取一个下标中位值K1= (1+N)/2,获取set1[K1]值与查找对象M进行比较。若set1[K1]等于M,则查找成功,返回查找位置;若set1[K1]小于M,则在[K+1,N]区间里再取中位值,进行查找比较;若set1[K1]大于M,则在[1,K-1]区间里再取中位值,进行查找比较。通过不断缩小查找区间范围,可以快速获取所需要查找的值。


fish_records = [1,1,2,3,6,7,8,18]
low = 0                             #查找范围下界
high = len(fish_records)-1          #查找范围上界
find_value = 7                      #要寻找的值
find_OK = False                     #是否找到标志,True为找到
i = 1
while low<=high:
    middle = int((low+high)/2)       #用int取整数,避免浮点数问题的发生
    if find_value == fish_records[middle]:   #找到时
        find_OK = True                       #设置标志为True
        break
    elif find_value>fish_records[middle]:   #没有找到,要找的值范围大于中位值时
        low = middle+1                      #范围在middle+1和high之间
    elif find_value<fish_records[middle]:   #没有找到,要找的值范围小于中间值时
        high = middle-1                     #范围在low和middle-1之间
    i += 1
    if find_OK:
        print('%d在列表下标%d处,找了%d次。'%(find_value,middle,i))
    else:
        print('要找的数%d没有!找了%d次。'%(find_value,i))

结果:

在这里插入图片描述

代码运算示意图:

在这里插入图片描述

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注编程网的更多内容!

--结束END--

本文标题: python列表与列表算法详解(2)

本文链接: https://www.lsjlt.com/news/132879.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • python列表与列表算法详解(2)
    目录2. 案例【三酷猫冒泡法排序】3. 案例【三酷猫二分法查找】总结1. 案例【三酷猫列表记账】 操作需求: (1)用列表对象记录三酷猫每天钓鱼的种类和数量 (2)统计三酷猫所钓...
    99+
    2022-11-12
  • python列表与列表算法详解
    目录1. 序列类型定义2. 列表的基础知识2.1 列表定义2.2 列表基本操作总结1. 序列类型定义 序列是具有先后关系的一组元素 序列是一维元素向量,元素类型可以不同 ...
    99+
    2022-11-12
  • Python 列表与链表的区别详解
    目录python 列表和链表的区别列表的实现机制链表链表与列表的差异python 列表和链表的区别 python 中的 list 并不是我们传统意义上的列表,传统列表——通常也叫作链...
    99+
    2022-11-12
  • python:列表详解
    目录列表list1、列表创建2、列表访问1)一维列表的访问2)二维列表的访问3、修改元素5、del命令6、列表运算1)列表相加2)列表相乘7、列表方法1) index(value[,...
    99+
    2022-11-12
  • Python数据结构与算法中的队列详解(2)
    传土豆 队列的一个典型方法是模拟需要以 FIFO 方式管理数据的真实场景。考虑这样一个游戏:传土豆。在这个游戏中,成员们围成一圈,并依次尽可能快地传递一个土豆。在某个时刻,大家停止传...
    99+
    2022-11-13
  • python之列表详解
    文章目录 一.创建列表1.基于弱数据类型语言的定义2.通过全局函数list()定义3.创建空列表 二.访问列表的值1.通过下标索引2.通过for循环遍历3.通过while循环遍历 ...
    99+
    2023-10-18
    python 开发语言 后端 列表
  • python计算列表元素与乘积详情
    目录插入代码块列表乘积计算插入代码块 使用sum函数: numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] print(sum(numbers)) 使...
    99+
    2022-11-11
  • python系列(三)python列表详
    博主QQ:819594300博客地址:http://zpf666.blog.51cto.com/有什么疑问的朋友可以联系博主,博主会帮你们解答,谢谢支持!本博文阅读目录:1)len函数//查看列表的个数2)序列[索引号] //查看索引号对应...
    99+
    2023-01-31
    系列 列表 python
  • Android列表实现(2)_游标列表案例讲解
    代码如下:import android.app.ListActivity; import android.database.Cursor; import android.os...
    99+
    2022-06-06
    游标 Android
  • Python 列表切片详解
    一、列表切片      切指–将某些东西切成小块。列表切片是从原始列表中提取列表的一部分的过程。在列表切片中,我们将根据所需内容(如,从何处开始,结束以及增量进行切片)剪切列表。      Python中符合序列的有序序列都支持切片(sli...
    99+
    2023-09-24
    python 开发语言
  • Python 列表排序详解
    在Python中,对列表进行排序有两种方法。 一种是调用 sort() 方法,该方法没有返回值,对列表本身进行升序排序。 cars = ['bmw', 'a...
    99+
    2022-11-12
  • Python入门之列表用法详解
    目录列表是什么列表的CRUD创建列表访问列表中的值更新列表删除元素拼接列表列表相乘判断遍历列表列表常用方法获取列表长度列表后面添加元素指定位置添加元素删除元素返回的是某个元素在列表里...
    99+
    2022-11-11
  • Python算法题----列表去重
    有这样一个列表[1, 1, 1, 2, 3, 3, 2, 4, 3, 4, 5, 5, 5, 6, 7, 8, 9, 9, 9, 9, 10, 10], 写一个函数,将其重复元素去除。这道题,方法很多的有没有。下面就演示一下茴香豆的四种写法...
    99+
    2023-01-31
    算法 列表 Python
  • Python算法题----逆序列表
        有这样一个列表[1, 2, 3, 4, 5, 6, 7, 8, 9]编程实现该列表逆序排列,将其变为[9, 8, 7, 6, 5, 4, 3, 2, 1] 。    题目有了,看看怎么答,逆序排列,只需要将第一个和倒数第一个,第二个...
    99+
    2023-01-31
    逆序 算法 列表
  • python列表详情
    目录1.列表2.使用格式3.一些很有用的函数4.元组 tuple5.元组的常用函数1.列表 python没有数组,而是引入了列表(list),列表可以存储任何类型的数据,而且同一个...
    99+
    2022-11-12
  • Python 列表list详解(超详细)
    文章目录 Python内置函数/方法详解—列表list1、创建列表1.1 使用 [ ] 创建列表1.2 使用 list() 函数 创建(转换为)列表 2、访问列表2.1 下标索引访问2....
    99+
    2023-08-31
    python 开发语言 pycharm 算法 后端
  • Python列表推导式详解
    目录Python列表推导式一、range()函数二、列表推导式三、代码可读性四、字典推导式五、集合推导式Python列表推导式 列表推导式是Python构建列表(list)的一种快捷...
    99+
    2023-05-15
    Python列表推导式 列表推导式 Python推导式
  • Python列表list详解篇(七)
    介绍:列表是最常用的python数据类型,它可以作为一个方括号内的逗号用分隔值出现。列表的数据项不需要具有相同的类型。创建一个列表,只要逗号分隔的不同数据项用方括号括起来即可。name=[‘’beijing,’shenzhen’,’nanj...
    99+
    2023-01-31
    详解 列表 Python
  • Python中列表索引A[:2]与A[:,2]的区别说明
    目录列表索引 A[ : 2 ]与A[ : , 2]区别创建一个列表访问列表中的值A[ : 2 ]与A[ : , 2]的区别python中[::]的含义[:-1][::-1][:,]列...
    99+
    2022-11-11
  • pythonrequestpost列表的方法详解
    目录request post 列表的方法原代码解决方案request post 数据中有list和dict方法可是数据中有一段是这样的requests.post数据是会提示未知错误r...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作