列表(可变数据类型)
列表的定义
列表是打了激素的数组,数组只能存储同种类型的数据,而列表像一个仓库,存储不同类型的数据.
l = [] ##定义一个空列表
l = [1] ##定义一个包含元素 “1” 的列表
l = [1,(1,2),"hello",[1,2]] ##定义一个包含元素的列表,元素可以是任意类 型,包括数值类型,列表,字符串等均可
列表的特性
- 索引
- 下标是从0开始计算,比如list[0]读取的是列 表的第1个元素;
- list[-1]读取的是列表的倒数第1个元素;
- 切片
>>> list
['hallo', 5, 'test']
>>> list[0:3:2]
['hallo', 'tast']
- 0代表从哪个索引开始切片;
- 3代表切片到哪个位置,并且不包含第三 个索引;
- 2代表切片的步长
- 重复
- 连接
列表的方法
增加:
- l.append() //末尾追加单个元素
- l.extend() //末尾追加多个元素
- l.insert() //指定位置插入单个元素
删除
- l.remove() //删除第一个遇到的元素值
- l.pop() //删除指定的索引所在的元素,默认删除最后一个
修改:直接根据索引进行修改
l[0]=”value”
l[0][1]=”value”
查看列表信息
- l.count() //查找某个元素出现的次数
- l.index() //查找某个元素最小的索引
排序
- l.sort() //列表排序
- l.reverse() //列表逆转
内置方法
min(),max(),len(),zip(),enumerate(),sum(),sorted(),reversed()
程序实例
- 通过列表实现堆栈的数据结构;
#!user/bin/env python
#coding:utf-8
"""
file: stack_mangement.py
date: 2017-08-26 10:39 AM
author: fang
version: 1.0
desc:
"""
def main():
print "欢迎来到栈的管理".center(70,"*")
stack = []
while 1:
print"""
{}
push(U) : 入栈
pop(O) : 出栈
view(V) : 查看
quit(Q) : 退出
{}
""".format("请选择操作".center(47, "="),"".center(40, "="))
judge=raw_input("请选择:")
if judge.lower()=="u":
num=raw_input("请输入入栈内容: ")
stack.append(num)
# stack[l]=num
print ">>>>>入栈成功!!!"
continue
elif judge.lower()=="o":
l = len(stack)
if l==0:
print ">>>>>栈为空"
continue
else:
stack.pop()
print ">>>>>出栈成功"
continue
elif judge.lower()=="v":
l = len(stack)
if l == 0:
print ">>>>>栈为空"
continue
else:
print """
{}
{}
{}
""".format("stack".center(40, "-"), stack,"".center(40, "-"))
continue
elif judge.lower()=="q":
print "谢谢使用,欢迎再来".center(70, "*")
break
else:
print ">>>>>您的输入有误,请重新输入:"
if __name__ == '__main__':
main()
元组(不可变数据类型)
元组的定义:
- t = () //定义一个空元组
- t = (1,) //元组只有一个元素时,加”,”,t=(1),t是int类型;
- t = (1,2,(1,2),[1,2]) //可以包含任何类型的数据结构
元组的特性
- 不可以修改元素内容,t[0]=”westos”,直接报错
- 分别赋值,name,age = (“westos”,10)
- 索引
- 切片
- 重复
- 连接
元组的方法
- t.count() //计算某个元素出现的次数
- t.index() //返回某个值的最小索引