python3学习笔记13(数据结构)
参考http://www.runoob.com/python3/python3-data-structure.html
列表
列表是可修改的。
列表方法让列表可以方便的作为一个堆栈来使用,堆栈作为特定的数据结构,最先进入的元素最后一个被释放(后进先出)。
其中用append()方法可以把一个元素添加的堆栈顶;可以用不指定索引的pop()方法把一个元素从堆栈顶释放出来,返回最后一个元素。
列表页可以用作队列,只是队列里是第一加入的元素,第一个取出来;拿列表做队列效率不高。在列表的最后添加或弹出元素速度快,然而在列表里插入或头部弹出速度不快(因为所有其他的元素都得一个一个移动)例如popleft()方法。
列表推导式
列表推导式提供了从序列创建列表的简单途径。应用程序将一些操作应用于某个序列的每个元素,最后用获得的结果作为生成新列表的元素,或者根据确定的判定条件创建子序列。
vec = [2,4,6]
vec1 = [3*x for x in vec]
#每个列表推导式在for之后跟一个表达式,如果希望推导出一个元组,必须用括号
print(vec1)
vec2 = [[x,x**2] for x in vec]
print(vec2)
vec3 = [3*x for x in vec if x >3] #if语句过滤
print(vec3)
vec4 = [3*x for x in vec if x <2]
print(vec4)
vec5 = [1,2,3]
vec6 = [x*y for x in vec for y in vec5 ]
print(vec6)
vec7 = [x+y for x in vec for y in vec5]
print(vec7)
vec8 = [vec[i]*vec5[i]for i in range(len(vec))]
print(vec8)
嵌套列表解析
Python的列表还可以嵌套。
#3x4矩阵列表
matrix = [
[1,2,3,4],
[5,6,7,8],
[9,10,11,12],
]
cr = [[row[i] for row in matrix] for i in range(4)]
#3x4矩阵列表转换为4x3列表
print(cr) #方法二
transposed = []
for i in range(4):
transposed.append([row[i] for row in matrix])
print(transposed)
del 语句
使用 del 语句可以从一个列表中依索引而不是值来删除一个元素。可以用del语句从列表中删除一个切割,或清空整个列表。
a = [-1,1,2,3,345,345,111.5]
del a[0]
print(a)
del a[2:4]
print(a)
del a[:]
print(a)
del a #也可以删除实体变量
print(a)
元组和序列
t = 12345,54321,'hello!' #元组由若干逗号分隔的值组成
t[0]
print(t[0])
print(t)
u = t,(1,2,3,4,5) #元组在输出时总是有括号的,以便于正确表达嵌套结构。
print(u)
集合
集合是一个无序不重复元素的集。基本功能包括关系测试和消除重复元素。
可以用大括号({})创建集合。注意:如果要创建一个空集合,你必须用 set() 而不是 {} ;后者创建一个空的字典,下一节我们会介绍这个数据结构。
basket = {'apple','orange','apple','pear','orange','banana'}
print(basket) #删除重复的
x1 = 'orange' in basket #检测成员是否存在集合中
print(x1)
x2 = 'crabgrass' in basket
print(x2) x3 = set('abcdacbabc')
x4 = set('alacazz')
print(x3)
print(x3-x4) #在a中有,b中没有
print(x3|x4) #在a或b有
print(x3&x4) #在a和b中同时有
print(x3^x4) #在a或b中的字母,但是不同时在a和b
x5 = {x for x in 'abracadabra' if x not in 'abc'} #集合也支持推导式
print(x5)
字典
序列是以连续的整数为索引,与此不同的是,字典以关键字为索引,关键字可以是任意不可变类型,通常是字符串或数值。
在同一个字典中,关键字必须是互不相同。
创建空的字典:{}
d = {'a':5601,'b':4000}
d['c'] = 4127
print(d)
print(d['a'])
del d['b']
print(d)
d['d'] = 4127
print(d)
print(list(d.keys()))
print(sorted(d.keys()))
print('d' in d)
print('e' in d)
print('d' not in d)
#构造函数dict()直接从键值对元组列表中构建字典
d1 = dict([('a',5601),('b',4000),('c',4127)])
print(d1)
#字典推导可以用来创建任意键和值的表达式词典
d2 = {x: x**2 for x in (2,4,6)}
print(d2)
#如果关键字只是简单的字符串,使用关键字参数指定键值对
d3 = dict(a= 5601,b= 4000,c= 4127)
print(d3)
python3学习笔记13(数据结构)的更多相关文章
- Python3+Selenium3+webdriver学习笔记13(js操作应用:弹出框无效如何处理)
#!/usr/bin/env python# -*- coding:utf-8 -*-'''Selenium3+webdriver学习笔记13(js操作应用:弹出框无效如何处理)'''from sel ...
- Python3学习笔记(urllib模块的使用)转http://www.cnblogs.com/Lands-ljk/p/5447127.html
Python3学习笔记(urllib模块的使用) 1.基本方法 urllib.request.urlopen(url, data=None, [timeout, ]*, cafile=None, ...
- SQL反模式学习笔记13 使用索引
目标:优化性能 改善性能最好的技术就是在数据库中合理地使用索引. 索引也是数据结构,它能使数据库将指定列中的某个值快速定位在相应的行. 反模式:无规划的使用索引 1.不使用索引或索引不足 2.使用了 ...
- Ext.Net学习笔记13:Ext.Net GridPanel Sorter用法
Ext.Net学习笔记13:Ext.Net GridPanel Sorter用法 这篇笔记将介绍如何使用Ext.Net GridPanel 中使用Sorter. 默认情况下,Ext.Net GridP ...
- Python3学习笔记 - 准备环境
前言 最近乘着项目不忙想赶一波时髦学习一下Python3.由于正好学习了Docker,并深深迷上了Docker,所以必须趁热打铁的用它来创建我们的Python3的开发测试环境.Python3的中文教程 ...
- golang学习笔记13 Golang 类型转换整理 go语言string、int、int64、float64、complex 互相转换
golang学习笔记13 Golang 类型转换整理 go语言string.int.int64.float64.complex 互相转换 #string到intint,err:=strconv.Ato ...
- springmvc学习笔记(13)-springmvc注解开发之集合类型參数绑定
springmvc学习笔记(13)-springmvc注解开发之集合类型參数绑定 标签: springmvc springmvc学习笔记13-springmvc注解开发之集合类型參数绑定 数组绑定 需 ...
- python3学习笔记(7)_listComprehensions-列表生成式
#python3 学习笔记17/07/11 # !/usr/bin/env python3 # -*- conding:utf-8 -*- #通过列表生成式可以生成格式各样的list,这种list 一 ...
- python3学习笔记(6)_iteration
#python3 学习笔记17/07/10 # !/usr/bin/env python3 # -*- coding:utf-8 -*- #类似 其他语言的for循环,但是比for抽象程度更高 # f ...
随机推荐
- MySql5.7多实例配置教程
最近朋友在搞在Linux上配置MySql5.7多实例教程,在网上查询了很多资料,一直报各种各样的错误,后来在网上搜了一篇博客,根据其配置,最近是配置成功了 参考配置连接:https://blog.cs ...
- Vue2.x路由的步骤
创建路由步骤: 1.引入vue-router库,可用最新版https://unpkg.com/vue-router 2.创建所需要的组件 3.创建router实例对象 4.在根实例中注册一下 => ...
- Flutter 开发小技巧
1.命令行运行flutter run之后iOS报错:Could not install build/ios/iphones/Runner.app on XXXXX. try lunching Xcod ...
- scrum第二次冲刺
1.本次冲刺内容 实现长大一条龙的登陆注册. 本次冲刺我们团队实现了长大一条龙的登录注册功能.我们的这个项目严格遵守MVC架构,采用前后端分离的策略.我们将登陆注册分为三层,DAO层:负责与数据 ...
- Beta发布用户使用报告
用户数量:13人 姓名如下(包括化名):张小斌.王瑞瑞.蛋蛋.小美.晨曦.小丽.张利刚.小闫.小谢.小崔.小欢欢.小胡胡.小霞霞 寻找的用户多为王者荣耀交流协会成员的同学,对PSP Daily软件有极 ...
- Anaconda安装(Windows)
Anaconda集成了python和各种常用工具. 目前有两个版本,分别包含了python2.7和python3.5,并且自动添加环境变量.去官网下载安装包. 1.安装其他模块.conda insta ...
- 常用的CMD & Linux命令
[CMD命令] 1.分行输入环境变量 使用echo %PATH%输出环境变量的时候没有分行输出,看起来十分麻烦: 通过xargs命令可以实现分行输出,命令如下: echo %PATH% | xargs ...
- AI之旅(3):升维与最小二乘法
前置知识 矩阵的逆 知识地图 首先我们将了解一种叫升维的方法,用已有特征构造更多的特征.接着通过对空间与投影建立一定的概念后,推导出最小二乘法. 当特征数量不足时 在上一篇<初识线性 ...
- javap反汇编命令
https://blog.csdn.net/qq_36330643/article/details/73841313 有关反汇编的具体
- 1040 mysql Too many connections
笔者在项目中遇到mysql 出现:1040 too many connections 异常,意思是超过数据库最大连接数,打不开表结构信息.笔者排除问题建议:1.查看程序代码是否存在BUG:2.检查代码 ...