python内置数据结构常见操作易错总结[更新ing...]

news/2025/1/16 2:31:44/

list

常用方法

  1. 切片->使用一个冒号

  2. 间隔->使用两个冒号

    a = [1,2,3,4,5]
    print(a[-3:])		# [3,4,5]
    print(a[::2])		# [1,3,5]
    print(a[1:5:2])		# [2,4]
    
  3. 添加元素

    • lst.append(value):一次添加一个元素
    • lst,insert(index,value):在索引为index的位置添加value
      NT:时间复杂度为O(n)
    • lst.extend([1,3]):一次添加一个列表
    • lst+=[1,3]: 效果同extend,注意这个是创建新列表,extend是在原列表上扩展
  4. 删除元素
    lst.remove(value):直接删除lst中值为value的元素,若value出现多次,则只删除第一次
    lst.pop(index):若不带参数则默认删除lst最后一个元素,带参数则删除此索引的元素
    del lst[2:] : 删除列表的切片序列

  5. in:可以用作遍历,也可以用作判断元素是否在这个列表中
    注意这是个遍历,要是单纯判断元素是否在可以使用set,效率更高

  6. 其他常用API

    1. clear:清楚列表所有元素

    2. index:查找某个value的索引

    3. count:统计某个元素出现次数

    4. sort:元素排序,使用key参数定制排序规则

      • 注意:
        • sort是列表的方法,使用时是lst.sort(),对本身lst排序;
        • sorted是一个函数,使用时是sorted(lst),不改变本身,返回新列表
      # 列表中元素为tuple,据元祖第二个值由小到大排序
      a = [(3,1),(4,1),(1,3),(5,4),(9,-10)]
      a.sort(key=lambda x:x[1])
      print(a)	
      # [(9, -10), (3, 1), (4, 1), (1, 3), (5, 4)]
      
    5. reverse:列表反转

      a = [4,1,2]
      a.reverse()
      print(a)	# [2,1,4]
      
    6. copy:浅拷贝,即只copy一层
      想要实现深拷贝可以使用copy模块中的deepcopy方法

扩展用法

list的这些方法可以很方便的当做stack使用,栈的pop和push在list中都可以O(1)实现
但是list做queue的效率就不够了,一般queue可以用deque实现

list的insert操作时间复杂度为O(n),即每次插入都要往后面移动复制一次👉需要频繁插入的操作都不适用list

还需要注意的是list是可变的,可变对象是不可哈希的,不可哈希的对象不能被映射,所以list不能作dict的键
如果需要使用list对象作键可以将list转成tuple,tuple可哈希,可以作dict的key

tuple

元组是一类不允许添加删除元素的特殊列表,即一旦创建后续不允许修改
tuple一般用在打包和解包处,即若函数有多个返回值时可以打包为一个元祖,赋值到等号左侧变量时解包
若确定对象后面不会被修改,可以使用元祖,因为元祖比list更节省内存

set

常用操作


  1. st.add(value): 向集合中添加元素
    c = st.copy()


  2. st.remove(value):删除st中值为value的元素,这里必须保证st中有value,不然会报错
    st.discard(value):有则删除,没有则不变(与remove一样,但是没有的时候不报错)
    st.pop():没有参数,随机删除,返回被删除的值

  3. 集合运算
    交集:union,|
    并集:intersection,&
    差集:difference(返回值),difference_update(改自身值),-
    对称差集:symmetric_difference(返回值),symmetric_difference_update(改自身值),^

    lst1 = [1,2,6,7]
    lst2 = [1,2,4,5]
    s1 = set(lst1)
    s2 = set(lst2)
    s3 = s1|s2	# {1, 2, 4, 5, 6, 7}
    s4 = s1.union(s2)# {1, 2, 4, 5, 6, 7}s5 = s1&s2	# {1, 2}
    s6 = s1.intersection(s2)# {1, 2}
    
    s1 = set([1,2,6,7])
    s2 = set([1,2,4,5])
    s3 = s1.symmetric_difference(s2)
    s4 = s1^s2
    print(s3)
    print(s4)
    print(s1)
    s1.symmetric_difference_update(s2)
    print(s1)
    
  4. 逻辑判断运算

    # 判断交集是否为空
    x1 = {"a", "b", "c"}
    x2 = {"e", "f", "g"}	
    print(x1.isdisjoint(x2))# 判断x1是否为x2的子集
    x1 = {"a", "b", "c"}
    x2 = {"a", "b", "c", "e", "f", "g"}
    print(x1.issubset(x2))# 判断x2是否为x1的子集,即x1是否包含x2
    x1 = {"a", "b", "c", "e", "f", "g"}
    x2 = {"a", "b", "c"}
    print( x1.issuperset(x2))
    

dict

  1. 查找元素

    1. dic[key]:必须要保证有key元素
    2. dic.get(key,‘error’):查找key,没有时返回‘error’
  2. 删除
    dic.pop(key):删除key节点,返回对应的value

  3. .items() .keys() .values() 均做列表输出,使用的时候要小心,都是O(n)的复杂度

  4. 排序
    sorted函数可以对字典进行排序处理,排序的结果放在一个列表中,然后返回这个列表

    dic={'a':1,'c':2,'b':5,'z':3,'d':0}
    print(sorted(dic))	# 默认对key排序输出
    print(sorted(dic.values()))
    print(sorted(dic.items(),key=lambda x:x[0]))
    print(sorted(dic.items(),key=lambda x:x[1]))
    # 对字典的排序实质上是把dict的内容用items()转换成一个个元祖,利用list对内容对二元祖的排序
    

deque

collections:python标准库,数据结构常用模块,常用类型有:deque、counter、defaultdict、OrderedDict、namedtuple

deque可以以近似O(1)的性能在deque的两端插入和删除元素

    • 元素

      • dq.append(元素):右端插入
      • dq.appendleft(元素):左端插入
      • dq.insert(index,value):在指定位置插入
    • 列表

      • dq.extend(列表):右端扩展
      • dq.extendleft(列表):左端扩展

  1. dq.pop():默认删除最右端元素并返回值(若dq为空,会报错)
    dq.pop(left):默认删除最左段元素并返回值,若dq为空会报错
    dq.remove(value):删除第一次出现的value(如无则报错)
    1. num=dq.count():统计元素个数
  2. 其他操作
    • dq.rotate(n):向右侧循环移动n步(若n为负数,则向左)
    • maxlen属性:只读属性,在创建deque时作为参数指定deque的最大长度

counter

属于collections 集合模块,能够简洁、高效的实现统计计数。
counter是dict字典的子类,拥有类似字典的key和value,但key为待计数的元素,value为对应元素出现的次数

counter和dict类似又有差别,在CSP中先用DICT就好啦,这里先不再展开

orderedDict

有序字典,与dict类似,只有一点不同,就是键值对的顺序会保留插入时的顺序

defaultfict

ChinaMap

heapq

heapq库是python的标准库之一,提供了构建小顶堆的方法和对小顶堆的基本操作方法,可以用于实现堆排序算法


http://www.ppmy.cn/news/53704.html

相关文章

解决播放swf视频提示“该版本过旧,不支持运行,请升级后使用”的问题

解决播放swf视频提示“该版本过旧,不支持运行,请升级后使用”的问题 1、修改hosts文件2、提升编辑hosts文件的权限3、独立播放器,也就是运行本地SWF的情况清理配置文件“settings.sol”(安全方法)删除Macromedia目录&a…

ts定义对象类型Record<string, any>;和object、Object的区别

Record Record 是 TS 内置的一个高级类型&#xff0c;是通过映射类型的语法来生成索引类型的&#xff1a; type Record<K extends string | number | symbol, T> { [P in K]: T; } 比如传入 a | b 作为 key&#xff0c;1 作为 value&#xff0c;就可以生成这样索引类…

蒸发器前氟离子超标的解决方法

深度除氟工艺 1、活性氧化铝&#xff1a;需PH调整至酸性 2、碳基/羟基磷灰石&#xff1a;再生次数有限制 3、反渗透膜&#xff1a;造价成本高 4、特种除氟树脂&#xff1a;预处理需做好 氟化物选择吸附树脂 Tulsimer CH-87 是一款去除水溶液中氟离子的专用的凝胶型选择性…

PostgreSQL 数据类型转换

各种数据类型&#xff08;日期/时间、integer、floating point和numeric&#xff09;转换成格式化的字符串及反过来从格式化的字符串转换成指定的数据类型&#xff0c;在实际操作中经常遇到。下面总结了一些常用的函数。 日期操作函数 函数返回类型描述实例to_char(timestamp…

ES7.x的查询语句及java查询语句

文章目录 ES 简介基本信息查询查看所有索引查看索引 mapping查索引中所有值过滤模糊查询去重过滤后去重 ES 简介 Elasticsearch 7.x 是一个基于 Lucene 的分布式搜索引擎&#xff0c;它提供了一个分布式全文搜索引擎&#xff0c;可以快速、准确地搜索、分析和存储海量数据。El…

什么是gpt4-如何用上gpt-4

gpt4主要强化了哪些功能 OpenAI尚未公布GPT-4的详细信息&#xff0c;不过可以根据OpenAI前CEO Sam Altman在2020年所发表的一篇博客中提到的&#xff0c;GPT-4可能会具有更强大和智能的能力&#xff0c;包括更准确的理解和表达自然语言、更高效的记忆和推理、更全面的知识和视…

问题错误功能测试报告

新手发帖&#xff0c;很多方面都是刚入门&#xff0c;有错误的地方请大家见谅&#xff0c;欢迎批评指正 <项目名称> 功能测试报告 订正历史记录 日期 版本 说明 作者 批准人 目 录 1. 简介 4 1.1 目标 4 1.2 预期读者 4 1.3 背景 4 1.4 参考资料 4 1.5 术语定义 4…

《Effective Python 编写高质量Python代码的59个有效方法》学习笔记4

尽量用辅助类维护程序状态而不是字典或元组 #python字典可以很好的保存某个对象在其生命周期里的动态内部状态 class SimpleGradebook:"""docstring for SimpleGradebook"""def __init__(self): #双下划线是系统定义的&#xff0c;一般用户可以…