5 列表与元组
>列表简介
>>是一种内建的数据结构,用来存储一系列的元素
>>同JS一样,由于解释性语言不必声明数据类型,所以数组的元素也可以很灵或的不相同。
>列表的运算
index索引运算:[]
切片运算:[:]
拼接运算+
重复运算*
成员运算in
长度运算len()
循环for()
>列表方法:
list.intex()可以返回任意的方法
my_list[2] = a #元素赋值
my_list.append()#末尾追加元素
my_list.extend()#末尾追加子表
my_list.insert()#任意位置插入元素
my_list.pop()结尾删除元素
my_lise.sort()#排序
my_list.remove()#删除任意位置元素
my_list.reverse()#倒序
>列表应用
>>内建函数:sum()求和,max()求最大值,min()求最小值
>>列表名本身就是一种指针和地址。所以在赋值是只是一个指针的指向赋值给另一个指针的指向
- <span style=”font-size:14px;”>程序一</span>
<span style=”font-size:14px;”>a = [1, 2, 3, 4]
b = a
b[1] = 100
print a[1]
程序二
a = [1, 2, 3, 4]
b = a[:]
b[1] = 100
print a[1]</span>
程序一的输出100,因为a和b指向同一个位置
程序二的输出1,因为a和b指向不同的位置。
>>交换列表中两个元素的值
<span style=”font-size:14px;”>def swap(lst, a, b)
tmp = lst[a]
lst[a] = lst[b]
lst[b] = lst[a]
x = [10, 20, 30]
swap(x, 0, 1)</span>
>>查找并返回元素位置
<span style=”font-size:14px;”>def search(lst, x):
for i in range(len(lst)):
if lst[i] == x:
return i
return -1</span>
也可以直接使用lst.index(待查找元素)直接进行查找
>>时间复杂度的计算
>二分查找
<span style=”font-size:14px;”>def bi_search(lst, v):
low = 0
up = len(lst) - 1
while low <= up
mid = (low + up) / 2
if lst[mid] < v:
low = mid + 1
elif lst[mid] == v:
return mid
else:
up = mid - 1
return -1</span>
>排序
>>选择排序

>>冒泡排序

>>使用内置函数
sorted(lst)
lst.sort()
>嵌套列表
students = [ [‘zhang’, 84], [‘wang’, 77], [‘li’, 100], [‘zhao’,53] ]
>列表的解析
>>作用:一种有源列表创建新列表的方法
>>语法:[表达式for 变量 in 列表 if 条件]
生成函数-变化范围-约束条件
普通方法
lst = []
for x in range(1, 10)
lst.append(x**2)
print lst
列表解析法:
lst = [x**2 for x in range(1,10) if x % 2 == 0]
生成函数x**2;生成范围1-10;生成条件x%2==0
>定义匿名函数lambda
g = lambda x: x ** 2
print f(8)
所以可以用一下程序实现嵌套列表的值排序
students = [ [‘zhang’, 84], [‘wang’, 77], [‘li’, 100], [‘zhao’,53] ]
students.sort(key = lambda x: x[1], reverse = true)
>元组
>>注意事项
1、元组同字符串一样具有不可变性,本质上是一个列表
2、append、extend、del等改变列表内容的函数不再适用,其它函数可以用
3、用括号直接创建元组(引号直接创建字符串,方括号直接创建列表)
4、元组的括号可以省略,直接用逗号隔开相同元组里的不同项
>>使用元组赋值
使用元组交换两个值
a, b = b , a
name, domai = ‘car@163.com‘.split(‘@’) //这样就直接将值赋给两个变量了。
>>函数和元组
使用元组可以返回多个函数值

>>DSU模式(decorate,sort,undecorete)修饰排序反修饰
<span style=”font-size:14px;”>def sort_by_length(words):
#decorate
t = []
for word in words:
t.append((len(word),word))
#将元素和元素长度组成一个二元组
#sort
t.sort(reverse = true)
#undecorate
res = []
for length, word in t:
res.append(word)
return res
</span>
<span style=”font-size:14px;”>
words.sort(key = lambda x:len(x),reverse =true)</span>
//巧妙地利用了元组对应的灵活性完成了合成和分割









