python第三章(下)

python第三章(下),第1张

python系列

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
  • 老师给的有问题,这里修改了

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/905336.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-15
下一篇2022-05-15

发表评论

登录后才能评论

评论列表(0条)

    保存