Python世界:数据结构易错点小结

Python世界:数据结构易错点小结

部分笔记汇总,持续刷新中。区别于其他笔记之处在于,主要记录易错点坑点。

总体


数据结构声明辨析

  • list []
  • tuple () const list
  • ditc {} hash
  • set res = set(list)

数据结构区别辨析

  • list,列表,内容可变,声明方式:[a, b,];有增删查改等操作
  • tuple,元组,内容不可变,声明方式:(a, b,);只有查的操作
  • dict,散列/字典,无序,键值对(关键词及对应值),声明方式:{'xx':yy, 'aa':bb, };主要用于查找,类似于hash表;key一旦加入则不可变,但键值可变
  • set, 无序,元素不重复,只有关键词;用于查找元素是否在这个集合中,便于快速查找。有点像枚举加Switch的功能。
  • tuple是一个不可改变的list,set是一个没有Value的dict,list,dict和set的数据是可变的,tuple数据是不可变的!

关联点

  • 序列:列表,元组,字符串
    • 判别 in/not in确认是否在
    • 取值 索引/切片
  • 列表和字典可相互嵌套,可变与不可变的限制仅限于当前一个层级。

参考资料:

list列表


高频操作

  • 删,del shoplist[0]
  • 增,list.append(x)
  • 查,直接索引即可
  • list中自带的sort函数,是原地修改

list切片,内存与浅拷贝简析

变量名赋值,只是引用拷贝的指针。对新变量的修改,会改变原变量指向的结果。mylist = shoplist,指向同一块内存

除非用切片遍历方式,来copy一块新内存并赋值给新变量,mylist = shoplist[:]

列表中的,append与insert有啥差异?

  • append,追加到末尾;1次1个元素
  • insert,追加到指定位置;1次1个元素
  • extend,将1个序列所有元素扩展到另一序列末尾。 1次多个元素

tuple元组


tuple

  • 元组只有查询的用途
  • 支持内部嵌套元组

String


字符串

  • 常用小函数
    • name.startswith('Swa')

    • name.find('war')

    • target_file.replace(tobe_backup_dir, "") # string中的replace函数,tobe_backup_dir目标带替换字符串;表征了替换为:""

dict字典


典型应用如address book

  • keys, name
  • values, details
  • the key must be unique
  • in/has_key,检查是否存在对应key

map


map, 一种映射方式, 作用到list的每个元素,映射关系为func,输出到迭代器中,iter = map(func, list), res = list(iter)

set


set

  • 无序集合,交、并、判
  • bri = set(['brazil', 'russia', 'india'])
相关推荐
宇木灵5 小时前
C语言基础学习-二、运算符
c语言·开发语言·学习
yangSimaticTech5 小时前
沿触发的4个问题
开发语言·制造
清水白石0085 小时前
隔离的艺术:用 `unittest.mock` 驯服外部依赖,让测试真正可控
python
舟舟亢亢5 小时前
算法总结——二叉树【hot100】(上)
java·开发语言·算法
码农小韩5 小时前
AIAgent应用开发——大模型理论基础与应用(五)
人工智能·python·提示词工程·aiagent
百锦再6 小时前
Java中的char、String、StringBuilder与StringBuffer 深度详解
java·开发语言·python·struts·kafka·tomcat·maven
Jonathan Star6 小时前
Ant Design (antd) Form 组件中必填项的星号(*)从标签左侧移到右侧
人工智能·python·tensorflow
普通网友7 小时前
多协议网络库设计
开发语言·c++·算法
努力努力再努力wz7 小时前
【Linux网络系列】:TCP 的秩序与策略:揭秘传输层如何从不可靠的网络中构建绝对可靠的通信信道
java·linux·开发语言·数据结构·c++·python·算法
deep_drink7 小时前
【论文精读(三)】PointMLP:大道至简,无需卷积与注意力的纯MLP点云网络 (ICLR 2022)
人工智能·pytorch·python·深度学习·3d·point cloud