序列(sequence)
基本概念
- 序列是Python中最基本的一种数据结构。序列用于保存一组有序的数据,所有的数据在序列当中都有一个唯一的位置(索引)并且序列中的数据会按照添加的顺序来分配索引
- 数据结构指计算机中数据存储的方式
序列的分类
- 可变序列(序列中的元素可以改变):例如 列表(list)
- 不可变序列(序列中的元素不能改变):例如 字符串(str)元组(tuple)
列表(list)
- 列表是Python中的一个对象
- 列表的作用
列表中可以保存多个有序的数据
列表是用来存储对象的对象
列表的使用
• 列表的创建:通过[]来创建一个空列表
切片
• + 和 *
- 可以将两个列表拼接成一个列表
- 可以将列表重复指定的次数 (注意2个列表不能够做乘法,要和整数做乘法运算)
• in 和 not in
• in用来检查指定元素是否在列表当中
• not in 用来检查指定元素是否不在列表当中
• len() 获取列表中元素的个数
• max() 获取列表中最大值
• min() 获取列表中最小值
• list.index(x[, start[, end]])
• 第一个参数 获取指定元素在列表中的位置
• 第二个参数 表示查找的起始位置
• 第三个参数 表示查找的结束位置
• list.count(x) 统计指定元素在列表中出现的个数
修改列表
• 通过切片来修改(起始就是给切片的内容重新赋值,但是赋值的内容必须是一个序列)
• 当设置了步长时,序列中元素的个数必须和切片中元素的个数保持一致
• 通过切片来删除元素
• del list[起始 : 结束]
• list = []
列表的方法
• append() 像列表的最后添加一个元素
• insert(arg1,arg2) 像列表指定位置插入一个元素 参数1:要插入的位置 参数2:要插入的元素
• extend(iterable) 使用一个新的序列来扩展当前序列(它会将该序列的中元素添加到列表中) 参数需要传递一个序列
• pop() 根据索引删除并返回指定元素
• remove() 删除指定元素 (如果相同值的元素有多个,只会删除第一个)
• reverse() 翻转列表
• sort(key=None,reverse=False) 用来对列表中的元素进行排序 reverse:True反序;False 正序
作业
1.现在有 a = [1,2,3,4,5,6] 不通过函数的形式实现列表的反转([6,5,4,3,2,1]) 并写出推导过程
li =[1, 2, 3, 4, 5, 6]
a = list(reversed(li))
print (a)
2.给 用户9次机会 猜1 - 10 个数字随机来猜数字。如果随机的数字和用户输入的数字一致则表示正确,如果不一致则表示错误。最终结果要求用户怎么也猜不对
for i in range(1,10):
num = input('请在1-10中随机输入一个数字,您一共有9次猜数机会,请您第{}次输入:'.format(i))
dat = [1, 2, 3, 4, 5, 6, 7, 8, 9]
dat.remove(int(num))
if int(num) not in dat:
j = 9 - int(i)
print('您猜错了,您还剩余{}次机会'.format(j))
print('您没有机会了,游戏结束!')
3.有两个列表 lst1 = [11, 22, 33] lst2 = [22, 33, 44]获取内容相同的元素
list1=[11,22,33]
list2=[22,33,44]
c=[]
d=list1+list2
for i in d:
if i in list1 and i in list2:
c.append(i)
print(c)
4.现在有8位老师,3个办公室,要求将8位老师随机的分配到三个办公室中
import random
for i in range(1,9):
room=random.randint(1,3)
print('{}号老师,您的办公室是{}'.format(i,room))