python系列
python第一章(上)
python第一章(下)
python第二章
python第三章(上)
前言
元组与元组操作
提示:以下是本篇文章正文内容,下面案例可供参考
元组
定义
- 元组(tuple)与列表类似,也是用来存放一组相关的数据。两者的不同之处主要有两点:
- 元组使用圆括号(),列表使用方括号[];
- 元组的元素不能修改,可以理解不能修改的列表
- 不能增加,也不能删除。
ts=('李白','张三','黄蓉')
print(ts)
ts=91,36,95,4,7
print(ts)
- 不使用()也可以定义元组
- 运行截图
- 只有一个元素的时候是单个字符串,要在一个元素后面加逗号能定义元组
ts=('李白')
print(type(ts))
ts=('李白',)
print(type(ts))
- 运行截图
操作
序列转换函数
- 之前介绍的列表、元组和前面学习的字符串都属于Python的一种基本数据类型——序列(sequence)。
- 序列的最大特点是元素的有序性,所以序列都是通过序号索引来访问元素的。
- 序列之间可以通过转换函数进行互相转换。
ts=('李白','张三','黄蓉')
print(type(ts))
print(ts)
ts=list(ts)
print(type(ts))
print(ts)
ts=tuple(ts)
print(type(ts))
print(ts)
- 运行截图
- 还有在字符串的时候讲过用split分隔符返回列表
综合应用
- 筛选300以内素数
- 具体算法
- 用i从2开始遍历整个列表;
如果第i个元素值为1,将后面所有能被i整除的下标对应的元素改写为0;
遍历结束后,保持为1的元素对应的下标即为要求的素数。
primes = [1] * 300;#将列表元素全部为1
primes[0:2] = [0,0]#将第一个和第二个元素改为0
for i in range(2 , 300):#从2开始遍历,
if primes[i] == 1:#判断当前对应的元素是否为1
for j in range(i + 1, 300):#j从i+1开始遍历,就是当前下标+1,判断能否被当前下标整除,
if primes[j] != 0 and j % i == 0:#
primes[j] = 0#能被整除说明不是素数
print("300以内的素数包括:")
for i in range(2 , 300):
if primes[i]==1:
print(i , end = ' ')
-
运行截图
-
请用二分查找法在列表中查找指定的元素。
-
按如下规则重复:
如果x > ls[mid],确定(mid,high]为下一查找区间,重新赋值low,计算新mid,继续;
如果x < ls[mid],确定[low,mid)为下一查找区间,重新赋值high,计算新mid,继续;
ls= [34,64,67,72,73,82,83,85,87,88,90,91,96,98]
n=int(input("请输入你要找的数"))
low = 0
high = len(ls) - 1
while low <= high:
mid = (low + high) // 2
guess = ls[mid]
if guess == n:
print("找到{},索引为{}!".format(guess, mid));
if guess > n:
high = mid - 1
else:
low = mid + 1
- 老师给的有问题,这里修改了