列表和元组

列表(可变数据类型)

列表的定义

列表是打了激素的数组,数组只能存储同种类型的数据,而列表像一个仓库,存储不同类型的数据.
定义一个空列表
list = []
定义一个包含元素的列表,元素可以是任意类
型,包括数值类型,列表,字符串等均可。
l = [1]
l = [1,(1,2),”hello”,[1,2]]

列表的特性


  • 索引
    下标是从0开始计算,比如list[0]读取的是列
    表的第1个元素;
    list[-1]读取的是列表的倒数第1个元素
  • 切片
    0代表从哪个索引开始切片;
    3代表切片到哪个位置,并且不包含第三
    个索引;
    2代表切片的步长;

list1
[‘fentiao’, 5, ‘male’]
list1[0:3:2]
[‘fentiao’, ‘male’]

  • 重复
    在元素后面加上*n(n代表一个正整数,n为几就重复几次)
  • 连接
    使用“+“连接
    “hello”+”world”
    “helloworld”

列表的方法

增加:

  • 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()反转

  1. 通过列表实现堆栈的数据结构;
  2. 通过列表实现队列的数据结构;
    堆栈是一个后进先出的数据结构,
    队列是一个先进先出的数据结构

l = []
入栈: l=[1] l = [1,2]
出栈: l = [1]

1=[]
入队:1=[1] 1=[1,2]
出队:1=[2]
welcome to stack mangement
p(U)sh:入栈
p(O)p:出栈
(V)iew:查看栈
(Q)uit:退出系统

元组(不可变数据类型)

元组的定义:

  • 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() //返回某个值的最小索引

test:
18位身份证的编码规则是:
前1、2位数字表示:所在省(直辖市、自治区)的代码
第3、4位数字表示:所在地级市(自治州)的代码
第5、6位数字表示:所在区(县、自治县、县级市)的代码;
第7—14位数字表示:出生年、月、日;
第15、16位数字表示:所在地的派出所的代码;
第17位数字表示性别:奇数表示男性,偶数表示女性;
第18位数字是校检码,用来检验身份证的正确性。
用户在输入身份证的过程中经常会输入错误,为了方便用户正确输入需要在输入过程中对用户的输入按照 6+8+4 的格式进行分组,实现一个方法接收输入过程中的身份证号,返回分组后的字符

  • 输入描述:
    输入数据有多行,每一行是一个输入过程中的身份证号

  • 输出描述:
    分组后的字符串

  • 示例1

输入:
    5021
    502104 198803
    5021041988033084
    502104198803308324

输出:

    5021
    502104 198803
    502104 19880330 84
    502104 19880330 8324

这里写图片描述

题目描述:
输入两个整数 n 和 m,从数列1,2,3…….n 中随意取几个数,使其和等于 m ,要求将其中所有的可能组合列出来

  • 输入描述:

每个测试输入包含2个整数,n和m

  • 输出描述:
    按每个组合的字典序排列输出,每行输出一种组合

  • 示例1 :

输入:
    5 5
输出:
    1 4
    2 3
    5

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值