python3

本文详细介绍了Python3中的两种重要数据结构——列表和元组。列表作为可变数据类型,支持多种操作,如增加元素(append、extend、insert)、删除元素(remove、pop)、修改元素、查看信息(count、index)、排序(sort、reverse)及内置方法。元组作为不可变数据类型,其特性与列表类似,但不允许修改元素,同时提供了count和index方法。文章还探讨了如何利用列表实现堆栈和队列,以及如何判断单词是否符合特定条件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

列表(可变数据类型)

列表的定义

列表是打了激素的数组,数组只能存储同种类型的数据,而列表像一个仓库,存储不同类型的数据.

l = []
l = [1]
l = [1,(1,2),”hello”,[1,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()

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

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

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

序列:字符串,列表,元组
不可变数据类型:str,tuple
可变数据类型:list

例题

输入一个正整数n,求n!(即阶乘)末尾0的个数

count=0
zero=0    #变量zero记录0的个数
def caculate(num):
    global count,zero
    for i in range(1,num):
        count=num/(5**i)
        zero+=count
        if count==0:
            return zero
n=input("please input n:")
print caculate(n)

小易喜欢的单词具有以下特性:
1.单词每个字母都是大写字母
2.单词没有连续相等的字母
3.单词没有形如“xyxy”(这里的x,y指的都是字母,并且可以相同)这样的子序列,子序列可能不连续。
例如:
小易不喜欢”ABBA”,因为这里有两个连续的’B’
小易不喜欢”THETXH”,因为这里包含子序列”THTH”
小易不喜欢”ABACADA”,因为这里包含子序列”AAAA”
小易喜欢”A”,”ABA”和”ABCBA”这些单词
给你一个单词,你要回答小易是否会喜欢这个单词。

def condition1(s):
    return s.isupper()

def condition2(s):
    for i in range(0,len(s)-1):
        if s[i] == s[i+1]:
            return False
    return True

def main():
    s = raw_input()
    if condition1(s) and condition2(s):
        print "Likes"
    else:
        print "Dislikes"

main()

将身份证号分隔开来输出

s = raw_input()
sL = len(s)


if sL < 6:
    print s
elif  6 < sL <= 14:
    print s[:6],s[6:]
else:
    print s[:6],s[6:14],s[14:]

判断是否是素数,并且输出有哪几对素数加起来的和等于该素数。

def isprime(num):
    for i in range(2,num):
        if num % i == 0:
            return False
    return True
num = input()
primeL = []
# 列表存储0-num中,和为num的所有质数对;eg:[(5,5),(3,7)].
doublePrime = []
for i in range(2,num):
    if isprime(i):
        primeL.append(i)
for i in range(0,len(primeL)):
    for j in range(i,len(primeL)):
        if primeL[i]+primeL[j] == num:
            doublePrime.append((primeL[i],primeL[j]))     
print len(doublePrime) 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值