上课笔记(11.11之前笔记)

一.数据结构的分类

1.数据结构中分为四大类:线性表,哈希表,树,图。

2.线性表(line table):呈现线性结构的一种数据结构。具有顺序性,也就是所有数据都是有序的;

          数组(array):连续的内存结构。大小固定,类型一致;数据查询数据的时间复杂度是O(1)

          链表:是一种物理存储单元上非连续,非顺序的存储结构;链表由节点组成,而节点由存储结构的数据域和存储下一节点地址的引用指针域组成;

3.哈希表(hash table):无序表

4.树(tree table)

5.图

二.列表

1.list(列表):底层是一个双向链表的线性表;

   创建或者定义列表:利用弱数据类型的特定,直接给[ ]定值,那么对应的变量就会自动变成列表类型;

 使用全局函数:b = list()    或      b = list([1,2,3,4])

(列表是存在堆里面的)

2.如何获取列表的长度:len()

3.如何获取每一个元素:

列表是有序的序列,它是线性表,线性表都是下角的角标

        a[0]                #获取第一个元素

        a[len(a) - 1]    #获取最后一个元素

4.   如何遍历列表:

       A. while:  必须是线性表! 

       B.for循环遍历

5.如何新增元素?如何删除元素?(使用dir列表对象,就可以查看列表中的所有属性和方法)

        append(新的元素)                     #在尾部添加新的元素

        insert(index , value)                #在index位置添加新的元素

        extend(新的列表)                       #合并列表

        remove(元素)                             #通过元素本身移除元素,如果元素不存在,则抛出异常

        pop(默认是从index = -1开始)      #默认移除最后一个元素,但是当传递了参数,表示移除对应下标的元素

        clear()                                               #清空列表

        index(元素)                                  #获取第一个元素所在的角标位置,如果元素不存在,则抛出异常

        count(元素)                                  #统计元素个数

        copy()                                          #拷贝列表,浅拷贝

        reverse()                                           #翻转列表顺序,注意和全局函数reversed的区别

        sort()                                                 #排序,一定要保证类型一致   

总结:结构为a.insert等等

 三.set集合

1.底层使用的一个hash table实现的;特点:不能重复,无序

2.python提供的set,就是有一个标准的哈希表,所以元素是不重复的,且无序的;

3.创建: 

                s = {1,2,3,4}

                s = set{ }

4.访问元素:

                set集合中的len跟列表中的一样,len获取元素个数;

                 只能使用for循环 迭代元素

5.常见方法:

                clear                                #清空集合

                copy                                #拷贝集合,浅集合

                add(元素)                        #插入元素

                pop(元素)                        #随机移除元素

                remove(元素)                  #通过元素本身移除元素,如果元素不存在,则抛出异常

                discard(元素)                   #通过元素本身移除元素,若元素不存在,也不会抛出异常             intersection                     #交集

                 union                               #并集

                 difference                        #差集

  总结:在集合中,相加运算也有去重的效果;

四.元组

1.定义:元组指的就是一组不变的数据类型,如:性别、四季、方向等等固定的值;

2.注意:元组是一个不可变的数据类型!!!

3.基本数据类型都是不可变的数据!

4. index(元素)                #获取一个元素所在的角标位置,如果元素不存在,则抛出异常;

    count(元素)                #统计元素数量;

5.注意:t = (1)  和 t = (1,)的区别;

              t = (1)是指一个整形,t = (1,)是一个元组;在元组中,逗号(,)是有特殊意义的。

 五.字典

1.字典:字典类型和集合一样,底层还是使用hash table实现的,只是字典对哈希表进行了封装,得到了k-v键值对的格式;

        注意:所有的键只能由字符串和数字充当;

2.创建或者定义字典类型

3.获取或者访问字典的值

                字典对象[key]                        #获取key对应的值

                字典对象[key]  = 值                      #修改key的值,或者常见一个键值对;

4.获取有多少个键值对

                len(d)

5.常见方法:

                clear                                                       #删除字典中的所有元素

                copy                                                       #复制

                get(key,[默认值])                                    #通过key获取值

        注意:假设aa在字典中不存在;d.get("aa")不会报错,会返回null;但是d["aa"]会报错,这是两者的区别!

        另外:如果想给不存在的aa的返回值设置一个新的值,则用d.get("aa",默认值),只有该返回值不存在,才会返回我们设置的默认值;

   

                items(后续用于遍历,很好使用)       #返回键值对

                keys()                                                     #获取键值对个数

                update()                                                 #合并字典,注意:当key重复了,则会更新这个值;

                del                                                          #是可以删除任何东西;

                del  变量                                                #删除变量 

                del  字典对象                                         #删除字典对象

                del   字典对象 key                                 #删除有一个对应的键值对     

     

                values()                                                 

                setdefault(key,[None])                          #设置键值对

                如果setdefault没有给值的话,就默认返回None;

                fromkeys()                                               #当所有键对应同一个值时,使用fromkeys()方法创建

                fromkeys                                                 #静态方法,可以通过dict.fromkeys(iterable)

                pop(key)                                                #LIFO删除键值对

注意:只要key写对了,就可以删除;如果key对应的值写错了,也是可以正确删除的;

                popitem()                                                 #LIFO(先进后删)随机删除并返回一个键值对

                items()                                                #返回键值对                                        

                update()                                              #合并字典;

        注意:如果key重复了,则会更新这个值;

               

 六.函数

1.什么是函数?

  函数是具有名称的功能代码的集合,函数就是封装了代码,本质就是为了实现代码的高度复用;

函数跟其他代码之间要空两行!这是规范!

2.函数是具有名称的功能代码的集合!

3.函数的分类:

        a.根据有无参数

                

        b.根据有无返回值

        

        c.定义者:

                --- 系统函数

                --- 自定义函数

                --- 第三方函数

4.函数部分:

                局部变量和全局变量

                函数调用的内存分析

                值传递和引用传递问题

5.局部变量和全局变量:形参是局部变量

打印结果:10   100 

                  20    200

6.注意:在python中,全局变量不允许被函数内部修改!!!是基于安全和可靠性!!!

7. 在python中,全局变量在函数中,如果需要修改它的值,则必须声明!!!

8.函数调用的内存分析

        通过分析函数在内存中存储和调用过程,来看看函数的本质

9.在python中,函数也是对象,函数也不能存储在栈中,它是存储在堆空间中;当我们调用函数时,函数就会进入执行栈,进行代码运行;(push ,推栈)等函数执行完成后,立刻释放执行栈的内存;(pop,弹栈)

10.值传递跟引用传递问题:

        值传递:函数的参数类型是数值类型,调用时,传递的仅仅是全局变量的值;因此在函数内部,修改传递后的值,不会影响全局变量;

        引用传递:函数的参数类型是对象,(引用|指针|地址),所以传递后,形参函数指向全局变量地址对应的内存区域,因此形参修改,全局变量也会随之修改;

11.默认值参数 -----  set 、end函数:对于函数中一些参数,如果调用时,参数大多数情况下是一个固定值的时候,我们可以设置这个固定值,便于调用;

                注意:函数中,普通参数(位置参数),一定要在默认值参数之前!

12. *+变量名  --------------  可变参数:表示一批参数,简化多个参数的传递;

        函数会自动将这些参数包装为一个元组对象

代码要扩展的时候,可以加上:

13. 关键字参数:【命名参数】

        将参数以键值对的形式传递过来,会被函数自动包装称字典对象;

注意:如果函数将来有可能需要扩展功能,建议添加可变参数关键字参数;

14. python在3.8版本后,提供过了类型声明功能,可以不使用,但是一定要认识,建议使用!

15. 在python中,只要是对象,就可以作为函数的参数;

16.  有括号是传的返回值,无括号传回的是函数本身!

17. 匿名函数: 没有名称的函数;

18. lambda表达式:本来就是简化函数的一种写法,在python中,如果函数较少,我们完成使用一行代码定义这个函数;

        格式:lambda [参数] :函数

18.

reduce可以转换!

19.偏函数:python中存在一种函数得特殊使用,称为偏函数;

如果函数在调用某个函数时,恰好某一个,某一些函数都是一个固定值(正好不是默认值),为了方便调用,我们可以通过特殊手段修改默认值;

格式   新的函数 =  partial(原函数名称,参数 = 新的值)

20.递归(recursion):虽然有些问题使用这个很方便,但是很占内存!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/138260.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【无标题】111

这里写自定义目录标题 欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants 创建一个自定义列表如何创建一个…

通讯协议学习之路(实践部分):UART开发实践

通讯协议之路主要分为两部分,第一部分从理论上面讲解各类协议的通讯原理以及通讯格式,第二部分从具体运用上讲解各类通讯协议的具体应用方法。 后续文章会同时发表在个人博客(jason1016.club)、CSDN;视频会发布在bilibili(UID:399951374) 本文…

Javascript享元模式

Javascript享元模式 1 什么是享元模式2 内部状态与外部状态3 享元模式的通用结构4 文件上传4.1 对象爆炸4.2 享元模式重构 5 没有内部状态的享元模式6 对象池7 通用对象池实现 1 什么是享元模式 享元(flyweight)模式是一种用于性能优化的模式&#xff0…

数据恢复工具推荐,高效恢复,这4款很实用!

很多电脑用户都会选择将文件直接保存在电脑上,但是在实际的操作过程中,数据丢失的情况难免会出现。而实用的数据恢复工具或许能有效帮助我们找回丢失的数据。电脑上有哪些使用效果比较好的数据恢复工具呢? 今天小编总结了几款好用的工具&…

leetcode:21. 合并两个有序链表

一、题目 函数原型: struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) 二、思路 合并两个有序链表为一个新的升序链表,只需要遍历两个有序链表并比较结点值大小,依次将较小的结点尾插到新链表即可。 三、代码…

C#中.NET Framework 4.8控制台应用通过EF访问已建数据库

目录 一、创建.NET Framework 4.8控制台应用 二、建立数据库 1. 在SSMS中建立数据库Blogging 2.在VS上新建数据库连接 三、安装EF程序包 四、自动生成EF模型和上下文 1.Blog.cs类的模型 2.Post.cs类的模型 3.BloggingContext.cs数据库上下文 五、编写应用程序吧 我们…

Vatee万腾数字化引领未来,vatee创新思维

随着数字化时代的全面来临,Vatee万腾正以其独特的创新思维,为未来描绘出令人瞩目的数字化画卷。在这个充满变革和机遇的时代,Vatee万腾所展现的数字化引领力和创新思维,成为业界的翘楚。 Vatee万腾的创新思维贯穿于其数字化战略的…

数据结构 | 队列的实现

数据结构 | 队列的实现 文章目录 数据结构 | 队列的实现队列的概念及结构队列的实现队列的实现头文件,需要实现的接口 Queue.h初始化队列队尾入队列【重点】队头出队列【重点】获取队列头部元素获取队列队尾元素获取队列中有效元素个数检测队列是否为空销毁队列 Que…

更新:扶风解析计费系统V1.8.2源码/免授权优化版+附教程/修正完整版

源码简介: 最新的扶风解析计费系统V1.8.2源码,它是修正完整版,免授权优化版附带了教程。是更新优化版最新 V1.8 版本免授权版本。 之前分享过1.7.1版本的扶风计费系统,该版本已经存在相当长的时间,并且一直没有进行更…

一文读懂:什么是RISC-V?为啥它是国产芯崛起的关键?

各位ICT的小伙伴们大家好呀。 提到CPU, 大家首先就会想到"卡脖子"事件。 X86和ARM的IP授权虽然方便,但是不自主和不可控, 一被限制就可能导致国内一夜间"无芯"可用。 今天我们就来聊聊一个解决芯片卡脖子的有效方式-…

多路复用IO:select、poll、epoll

文章目录 一、常见的IO模型二、什么是多路IO复用?三、select、poll、epollselectpollepoll 四、总结 一、常见的IO模型 概念优点       缺点适用场景阻塞IOBlocking IO当应用程序执行IO操作时,会被阻塞,直到数据准备好或者IO操作完成才…

项目管理工具:提高团队协作效率,确保项目按时完成

项目管理对于企业的成功至关重要,一个好的项目管理工具可以提高团队协作效率,确保项目按时完成,并保持项目进度的高效跟踪。 近年来,一款名为“进度猫”的项目管理工具逐渐崭露头角,它以其独特的功能和优势&#xff…

删除快一年的数据,能够恢复吗?

在数字化时代,数据已经成为了企业和个人生活中不可或缺的一部分。然而,由于各种原因,我们有时会需要删除某些数据,比如过期的文件、无用的照片或者账号下的旧信息等。但是,当我们删除这些数据后,是否真的能…

提高生产效率和质量,这个方式很有效

在当今竞争激烈的市场环境下,企业需要不断提高生产效率和质量水平以保持竞争优势。而精益生产正是一种能够帮助企业实现这一目标的方法。其中,持续改善是精益生产的核心理念之一。它是指通过不断地寻找和消除浪费,改善流程和提高效率来实现质…

PHP中$_SERVER全局变量

在PHP中,$_SERVER 是一个全局数组变量,它包含了有关服务器和当前脚本的信息。$_SERVER 数组中的每个元素都是服务器环境的一个参数,如请求的方法、请求的 URI、客户端 IP 地址等。 PATH 系统环境变量的值,包含了多个目录的路径…

Xmind 24 for Mac思维导图软件

XMind是一款流行的思维导图软件,可以帮助用户创建各种类型的思维导图和概念图。 以下是XMind的主要特点: - 多样化的导图类型:XMind提供了多种类型的导图,如鱼骨图、树形图、机构图等,可以满足不同用户的需求。 - 强大…

通过 Kaptcha 插件生成字符验证码

Kaptcha 是 Google 的⼀个⾼度可配置的实⽤验证码⽣成⼯具,我们选择的是⼀个适配SpringBoot的 开源项⽬ 生成的验证码效果如下: 原理 验证码可以客户端生成,也可以服务器生成. 对于普通的字符验证码, 后端通常分两部分: ⼀:⽣成验…

能跟“猫主子”聊天了!生成式AI最快5年内破译第一种动物语言

image.png ChatGPT用它自己的方式来理解世界,类似的技术是否也能用来学习动物的语言? 所罗门能够与动物交流并不是因为他拥有魔法物品,而是因为他有观察的天赋。 ——康拉德・劳伦兹《所罗门王的指环》 在《狮子王》、《疯狂动物城》等以动…

“颠覆·挑战·极致”华瑞指数云ExponTech WDS新一代产品重新定义企业存储和数据架构

数字经济发展,离不开数据这一信息时代的“新能源”。当数据爆发式增长,企业何处寻得一款在性能和成本上皆具备良好表现的“储能仓”?国内数据存储领域领先厂商华瑞指数云ExponTech自主研发的高性能、高可靠的分布式存储产品ExponTech WDS成为…

SCADA系统在化工行业应用解决方案和注意事项

SCADA系统在化工行业的数字化工厂中具有广泛的应用解决方案。SCADA系统通过实时监控和远程控制,帮助化工企业实现生产过程的自动化和数字化管理。以下是化工行业的SCADA系统行业应用中可以解决的客户痛点以及相关的详细设计说明: 远程监测和控制&#xf…