上一篇:流程控制-Python<二>

  1. 因为列表具有pop、append、insert方法,因此列表可以当作堆、栈使用。由于性能问题,不建议当作堆。(堆:队列优先,先进先出(FIFO—first in first out)栈:先进后出(FILO—First-In/Last-Out))
  2. 列表的pop、insert方法,使得列表可以当作队列使用,先入先出,但是在列表的开头做插入或者弹出都非常慢,因为要移动其他元素。需要用到队列,建议使用collections.deque。
  3. 可以使用map来创建队列,map(func,*iterables)
    1. >>> list(map(lambda x:x**2,range(23)))
    2. [0, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100, 121, 144, 169, 196, 225, 256, 289, 324, 361, 400, 441, 484]
  4. 创建列表的"[ ]",可以包含复杂的表达式,和嵌套函数
    1. >>> test=[ x**2 for x in range(3) ]
    2. >>> test
    3. [0, 1, 4]
  5. 列表删除元素方法及删除列表方法:remove、pop、clear、del。remove与pop都只能删除一个元素、clear清空列表。del可以切片删除。
    1. >>> test=[0,1,2,3,4]
    2. >>> test.remove(3)
    3. >>> test
    4. [0, 1, 2, 4]
    5.  
    6. >>> test=[0,1,2,3,4]
      >>> test.pop()
      4
      >>> test
      [0, 1, 2, 3]
      >>>
      >>> test.pop(1)
      1
      >>> test
      [0, 2, 3]
      >>>
    7.  
    8. >>> test=[0,1,2,3,4]
      >>> test.clear()
      >>> test
      []
    9.  
    10. >>> test=[0,1,2,3,4]
      >>> del test[0:2]
      >>> test
      [2, 3, 4]
      >>> del test[:]
      >>> test
      []
      >>> del test
      >>> test
      Traceback (most recent call last):
        File "<stdin>", line 1, in <module>
      NameError: name 'test' is not defined
      >>>
  6. 序列主要以下几种类型:
    • 3种基本序列类型(Basic Sequence Types):list、tuple、range (补:range() 函数返回的结果是一个整数序列的对象,而不是列表。tuple就是元组)
    • 专门处理文本的附加序列类型(Text Sequence Types):str
    • 专门处理二进制数据的附加序列类型(Binary Sequence Types): bytes、bytearray、memoryview

    按照序列是否可被改变分类:

    • 可变序列: list
    • 不可变序列:tuple、str
  7. tuple元组是标准的序列类型,不支持个别项目分配
    1. >>> a=6,7,8,89,9
    2. >>> a
    3. (6, 7, 8, 89, 9)
    4. >>> a[0]=2
    5. Traceback (most recent call last):
    6. File "<stdin>", line 1, in <module>
    7. TypeError: 'tuple' object does not support item assignment
    8. >>>

    但是tuple可以包含可变对象

    1. >>> a=43,4,5,6,[4,4,4,4]
    2. >>> a
    3. (43, 4, 5, 6, [4, 4, 4, 4])
    4. >>> a[4][0]=99999
    5. >>> a
    6. (43, 4, 5, 6, [99999, 4, 4, 4])
    7. >>>
  8. tuple的创建,当为空元素和一个元素的情况
    1. >>> a=()
    2. >>> a
    3. ()
    4. >>> a=0,
    5. >>> a
    6. (0,)
    7. >>>

    tuple的解压缩

    1. >>> a,b,c=3,4,5
    2. >>> a
    3. 3
    4. >>> b
    5. 4
    6. >>> c
    7. 5
    8. >>>

    tuple的打包

    1. >>> a=3,4,5,5
    2. >>> a
    3. (3, 4, 5, 5)
    4. >>>
  9. 字典的键必须是不可变的对象,例如字符串、数字、元组且元祖不能直接或间接的包含可变对象。字典的健不可以为列表,因为列表可以使用索引分配、del 切片 、append、extend等方法更改list对象。
  10. 想要在相反的情况下循环一个列表,可以使用reversed函数
    1. >>> for i in reversed(range(1,6,1)):
    2. ... print(i)
    3. ...
    4. 5
    5. 4
    6. 3
    7. 2
    8. 1
    9. >>>
  11. is 、 is not 判断元素是否相等
    1. >>> a=[]
    2. >>> b=[]
    3. >>> a is b
    4. False
    5. >>> a=9
    6. >>> b=9
    7. >>> a is b
    8. True
    9. >>> a is not b
    10. False
    11. >>>
  12. in、not in 判断是否在某个序列里
    1. >>> test="basecee"
    2. >>> 'a' in test
    3. True
    4. >>> 'f' in test
    5. False
    6. >>> 'f' not in test
    7. True
    8. >>> "ba" in test
    9. True
  13. 所有的比较运算符都有相同的优先级,比所有的数值运算符都要低。 这里‘< ,>’优先级低于‘+’
    1. >>> 6+8>12
    2. True
    3. >>> 13<6+9
    4. True
    5. >>>
  14. 布尔运算符的优先级低于比较运输符
    1. >>> 12==10 or 10==10
    2. True
    3. >>> 10>5 and 9<0
    4. False
    5. >>>

阅读网址:https://docs.python.org/3/tutorial/datastructures.html

数据结构-Python3.7<三>的更多相关文章

  1. COJ966 WZJ的数据结构(负三十四)

    WZJ的数据结构(负三十四) 难度级别:C: 运行时间限制:20000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 给一棵n个节点的树,请对于形如"u  ...

  2. COJ967 WZJ的数据结构(负三十三)

    WZJ的数据结构(负三十三) 难度级别:C: 运行时间限制:7000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 请你设计一个数据结构,完成以下功能: 给定一个大 ...

  3. COJ970 WZJ的数据结构(负三十)

    WZJ的数据结构(负三十) 难度级别:D: 运行时间限制:1000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 给你一棵N个点的无根树,点和边上均有权值.请你设计 ...

  4. COJ968 WZJ的数据结构(负三十二)

    WZJ的数据结构(负三十二) 难度级别:D: 运行时间限制:5000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 给你一棵N个点的无根树,边上均有权值,每个点上有 ...

  5. COJ969 WZJ的数据结构(负三十一)

    WZJ的数据结构(负三十一) 难度级别:D: 运行时间限制:3000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 A国有两个主基站,供给全国的资源.定义一个主基站 ...

  6. COJ 0967 WZJ的数据结构(负三十三)

    WZJ的数据结构(负三十三) 难度级别:E: 运行时间限制:7000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 请你设计一个数据结构,完成以下功能: 给定一个大 ...

  7. COJ 0970 WZJ的数据结构(负三十)树分治

    WZJ的数据结构(负三十) 难度级别:D: 运行时间限制:1000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 给你一棵N个点的无根树,点和边上均有权值.请你设计 ...

  8. 20172328 2018-2019《Java软件结构与数据结构》第三周学习总结

    20172328 2018-2019<Java软件结构与数据结构>第三周学习总结 概述 Generalization 本周学习了第五章:队列.主要内容包含队列的处理过程.如何用对例如求解问 ...

  9. 20172328《程序设计与数据结构》实验三 敏捷开发与XP实践报告

    20172328<程序设计与数据结构>实验三 敏捷开发与XP实践报告 课程:<程序设计与数据结构> 班级: 1723 姓名: 李馨雨 学号:20172328 实验教师:王志强 ...

随机推荐

  1. ubuntu服务器搭建DVWA站点

    把DVWA里面的文件夹拷贝到/var/www/html里面去 1.安装之前先更新系统 sudo apt update 2.安装Apache2 sudo apt install apache2 3.安装 ...

  2. FTP主动模式与被动模式,及java FTPClient模式设置

    FTP的主动模式与被动模式 FTP服务器使用20和21两个网络端口与FTP客户端进行通信. FTP服务器的21端口用于传输FTP的控制命令,20端口用于传输文件数据. FTP主动模式: FTP客户端向 ...

  3. FFmpeg原始帧处理-滤镜API用法详解

    本文为作者原创,转载请注明出处:https://www.cnblogs.com/leisure_chn/p/10429145.html 在FFmpeg中,滤镜(filter)处理的是未压缩的原始音视频 ...

  4. Codeforces Round #525 (Div. 2) E. Ehab and a component choosing problem 数学

    题意:给出树 求最大的sigma(a)/k k是选取的联通快个数   联通快不相交 思路: 这题和1个序列求最大的连续a 的平均值  这里先要满足最大平均值  而首先要满足最大  也就是一个数的时候可 ...

  5. poj3280

    将给定字符串用最小代价(添加,删除)变为回文串. dp:dp[i][j]表示将i-j变为回文串的最小代价. 若s[i]==s[j],则dp[i][j]=dp[i+1][j-1] 否则,若s[i+1]- ...

  6. What does git fsck stand for?

    fsck -> File System ChecK https://stackoverflow.com/questions/21151945/what-does-git-fsck-stand-f ...

  7. java 手动实现远程执行功能(深入理解java虚拟机)

     1.功能类 功能类共有五,分别是: package org.jvm; import java.io.*; /** * 对字节数组操作的工具类 */ public class ByteUtils { ...

  8. Spring,为内部方法新起一个事务,此处应有坑。

    事务的作用,使我们操作能够连贯起来.而spring则是提供了一个更简单的方法,只要使用 @Transactional 一个注解,就可以保证操作的连贯性了. 普通用法,稍后再说,这里要说的是: 在最外面 ...

  9. 【Spark调优】Shuffle原理理解与参数调优

    [生产实践经验] 生产实践中的切身体会是:影响Spark性能的大BOSS就是shuffle,抓住并解决shuffle这个主要原因,事半功倍. [Shuffle原理学习笔记] 1.未经优化的HashSh ...

  10. 【转载】MyBatis JdbcType 与Oracle、MySql数据类型对应关系详解

    [原文链接]:MyBatis JdbcType 与Oracle.MySql数据类型对应关系详解 1. Mybatis JdbcType与Oracle.MySql数据类型对应列表 2. Mybatis ...