python3

来源:互联网 发布:c语言取反符号怎么按 编辑:程序博客网 时间:2024/06/05 07:41

列表(可变数据类型)

列表的定义

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

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=0zero=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 zeron=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 Truedef 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 selif  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 Truenum = 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)