上课笔记(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):虽然有些问题使用这个很方便,但是很占内存!

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mozilla 面向基于 Debian 的 Linux 发行版

导读Mozilla 公司今天发布新闻稿,表示面向 Debian、Ubuntu 和 Linux Mint 等基于 Debian 的发行版,推出了.deb 格式的 Firefox Nightly 浏览器安装包,便于用户在上述发行版中更轻松地安装。 本次更新的亮点之一在于采用 APT 存储库&#xff0…

C++20 Text formatting

C20 Text formatting 格式化字符串&#xff0c; 和 python 类似。 std::formatter - cppreference.com string — Common string operations — Python 3.12.0 documentation 新格式库位于 <format> 头文件中。格式库基于 Python3 中的 str.format() 方法建模。格式…

css实现元素四周阴影

前言 首先确定的是需要使用box-shadow这一属性 语法如下&#xff1a; box-shadow: h-shadow v-shadow blur spread color inset; h-shadow&#xff1a;表示水平方向上的阴影偏移量&#xff0c;必须指明&#xff0c;可以是正数、负数、0&#xff0c;如果为正数左方有阴影&…

Spring全家桶源码解析--2.3 Spring bean 的依赖注入--@Autowired@Value

文章目录 前言一、Autowired&Value&#xff1a;1.1 Autowired&#xff1a;1.2 Value&#xff1a; 二、依赖注入&#xff1a;2.1 注入点获取&#xff1a;2.2 通过 populateBean 入口依赖注入2.2.1 populateBean &#xff1a;主要通过 postProcessProperties 方法进行依赖注入…

医院安全(不良)事件管理系统源码 不良事件报告全套源码

不良事件管理系统是一种专为企业或组织设计的软件工具&#xff0c;用于跟踪、记录和管理不良事件。该系统可以有效地整合不良事件的收集、分类、分析和报告&#xff0c;帮助企业及时识别和处理不良事件&#xff0c;从而降低风险和损失。通过实时监控和自动化报告&#xff0c;该…

论文精读 MediaPipe Hands

MediaPipe Hands:On-device Real-time Hand Tracking MediaPipe手势&#xff1a;设备上的实时手势跟踪 论文地址&#xff1a;2006.10214.pdf (arxiv.org) 源码地址&#xff1a;GitHub - vidursatija/BlazePalm: PyTorch 目录 摘要 介绍 架构 BlazePalm Detector Hand L…

蓝桥杯算法心得——拼数(排列型回溯dfs)

大家好&#xff0c;我是晴天学长&#xff0c;排列型的dfs&#xff0c;在一些需要暴搜的题中很中很重要&#xff0c;需要的小伙伴可以关注支持一下哦&#xff01;后续会继续更新的。&#x1f4aa;&#x1f4aa;&#x1f4aa; 1) .拼数 2) .算法思路 超级递归 1.遍历数组&#…

玩了个锤子游戏小程序搭建流程:探索深度与逻辑的结合

随着移动互联网的普及&#xff0c;小程序已经成为了越来越多用户的选择。在这个背景下&#xff0c;玩了个锤子游戏小程序应运而生&#xff0c;它为用户提供了一个全新的游戏体验。那么&#xff0c;如何搭建这样一个小程序呢&#xff1f;本文将为大家详细介绍玩了个锤子游戏小程…

GoLong的学习之路(二十三)进阶,语法之并发(go最重要的特点)(锁,sync包,原子操作)

这章是我并发系列中最后的一章。这章主要讲的是锁。但是也会讲上一章channl遗留下的一些没有讲到的内容。select关键字的用法&#xff0c;以及错误的一些channl用法。废话不多说。。。 文章目录 select多路复用通道错误示例并发安全和锁问题描述互斥锁读写互斥锁 syncsync.Wait…

go学习之接口知识

文章目录 接口1.接口案例代码展示2.基本介绍3.基本语法4.应用场景介绍5.注意事项和细节6.接口编程经典案例7.接口与继承之间的比较8.面向对象编程--多态1&#xff09;基本介绍2&#xff09;快速入门3&#xff09;接口体现多态的两种形式 9.类型断言1&#xff09;先看一个需求2&…

单独设置echarts图例样式

参考&#xff1a;echarts-legend legend: [{data: [{name: 正常,icon: rect}],itemWidth: 16,itemHeight: 4,top: 6%,left: 35%,textStyle: {color: #626C78,fontSize: 14}},{data: [{name: 异常,icon: rect}],itemWidth: 16,itemHeight: 4,top: 6%,left: 50%,textStyle: {col…

2013年01月16日 Go生态洞察:并发不是并行

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

京东数据运营与分析:如何全面获取电商销售数据?

随着电商行业的快速发展&#xff0c;数据分析成为了电商运营中一个非常重要的环节&#xff0c;这一环往往能够帮助品牌方来提升销售业绩和管理效率。然而&#xff0c;如何获取到电商平台中详细、全面的销售数据是很多电商品牌方所关心的问题&#xff0c;事实上&#xff0c;第三…

GitHub加速配置

1. 找到要加速的域名 GitHub&#xff1a;github.com&#xff08;这只是加载主页面的&#xff09;GitHub下载&#xff1a;codeload.github.com&#xff08;不唯一&#xff0c;自己去下载链接看&#xff09; 2. 用域名到DNS解析服务器地址 ITDOG 3. 修改 Hosts 文件 依据解…

ai批量剪辑矩阵无人直播一站式托管系统源头技术开发

一、剪辑技术开发 智能剪辑&#xff1a;咱们研发公司自主研发的&#xff0c;包括算法&#xff0c;算法是阶乘算法&#xff0c;无限产出&#xff0c;六大剪辑模式已经满足当下需求了&#xff0c;当然剪辑出的视频可以一键发布&#xff0c;也可以内部批量发布&#xff0c;都可以的…

100G 最小封装光模块——SFP112光模块

10月易天团队远赴英国格拉斯哥参加展会&#xff0c;在ECOC展会上认识和学习了许多新的产品和技术&#xff0c;其中一款备受关注的是100G SFP112光模块&#xff0c;据说它是全球最小封装的模块。下面就跟着小易一起来了解一下这位新晋级的“大咖”吧&#xff01; 100G SFP112采…

基于SpringBoot的SSMP整合案例(实体类开发与数据层开发)

实体类开发 导入依赖 Lombok&#xff0c;一个Java类库&#xff0c;提供了一组注解&#xff0c;简化POJO实体类开发<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId> </dependency>lombok版本由SpringB…

k8s笔记资源限制,亲和和性 污点和容忍

镜像下载失败 当宿主机资源不足时&#xff0c;会把pod kill &#xff0c;在其他node 重建 在宿主机放可能多的资源 requests(请求) limits(限制) 超出百分比 容器 pod namespace级别 pod使用资源过多&#xff0c;导致宿主机资源不足&#xff0c;会导致重建pod cpu 内存限…

Riskified: 2023年电商政策滥用问题恶化,正严重挑战商家盈利底线

2023年11月14日&#xff0c;中国上海 —— 近日&#xff0c;由全球领先的电子商务欺诈和风险智能解决方案提供商 Riskified 发布的《政策滥用及其对商家的影响&#xff1a;2023年全球参考基准》报告显示&#xff0c;政策滥用问题正进一步恶化&#xff0c;超过九成电商商家正在承…

只有开源才能拯救AI

导语 | 随着 AI 技术的蓬勃发展&#xff0c;大模型的开源化正成为人工智能领域的新潮流&#xff0c;但同时引发的伦理和安全风险也饱受大家关注&#xff0c;如何把握平衡其中的尺度成为开源的一大难题。我们又应该如何有效进行开源治理&#xff1f;未来将走向何方&#xff1f;今…