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()
- 通过列表实现堆栈的数据结构;
- 通过列表实现队列的数据结构;
堆栈是一个后进先出的数据结构,
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)
阅读全文
0 0
- python3
- Python3
- python3
- Python3
- Python3
- Python3
- python3
- python3
- python3
- Python3
- python3
- python3
- Python3
- Python3
- python3
- Python3
- python3笔记
- python3 多线程
- HDU6165 FFF at Valentine(深搜dfs,2017 HDU多校联赛 第9场)
- HDU 5792 World is Exploding(树状数组+离散化)
- NYOJ 2358(可能不存在的题-多校脸萌六)LLM找对象-dp
- SQL跟踪获取方法
- android开发之系统服务(检测网络是否通畅与开关WiFi)
- python3
- angular学习总结四——路由的用法
- 【CentOs7.x】- 安装httpd服务
- js的Base64编码与解码
- 算法笔记学习1
- HYSBZ 2565 Manacher算法
- 基本算法:生成元素数组的所有排列(permute)
- PHP进阶(第五弹:文件系统)
- 排序算法(Java)