当前位置: 首页 > news >正文

Python-循环结构解析

循环是计算机科学运算领域的用语,也是一种常见的控制流程。循环是一段在程序中只出现一次,但可能会连续执行多次的代码。循环中的代码会执行特定的次数,或者是执行到特定条件成立时结束循环,或者是针对某一集合中的所有项目都执行一次。

Python提供了两种主要的循环结构:for循环和while循环。

for-in循环

如果明确知道循环执行的次数,推荐使用for-in循环

for 变量 in 可迭代对象:# 循环体# 每次迭代执行这里的代码
# 遍历列表
fruits = ["apple", "banana", "cherry"]
for fruit in fruits:print(fruit)# 遍历字符串
for char in "Python":print(char)# 使用range()函数
for i in range(5):  # 0到4print(i)for i in range(2, 6):  # 2到5print(i)for i in range(0, 10, 2):  # 0到9,步长为2print(i)

range函数:

  1. range(101):可以用来产生0到100范围的整数,需要注意的是取不到101。
  2. range(1, 101):可以用来产生1到100范围的整数,相当于是左闭右开的设定,即[1, 101)。
  3. range(1, 101, 2):可以用来产生1到100的奇数,其中2是步长(跨度),即每次递增的值,101取不到。
  4. range(100, 0, -2):可以用来产生100到1的偶数,其中-2是步长(跨度),即每次递减的值,0取不到。
# 同时获取索引和值
for index, value in enumerate(fruits):print(index, value)# 遍历字典
person = {"name": "Alice", "age": 25, "city": "New York"}
for key in person:  # 遍历键print(key)for value in person.values():  # 遍历值print(value)for key, value in person.items():  # 同时遍历键和值print(key, value)# 并行遍历多个序列
names = ["Alice", "Bob", "Charlie"]
ages = [25, 30, 35]
for name, age in zip(names, ages):print(name, age)# 循环变量命名为_
import time
for _ in range(36):print('hello, world')time.sleep(1)

while循环

如果要构造循环结构但是又不能确定循环重复的次数,推荐使用while循环。

while 条件:# 循环体# 当条件为True时执行这里的代码
# 基本while循环
count = 0
while count < 5:print(count)count += 1# 无限循环(通常配合break使用)
while True:user_input = input("输入'quit'退出: ")if user_input == "quit":print(f"你输入了:{user_input},退出")breakprint(f"你输入了: {user_input}")

循环控制语句

break语句

break用于完全终止循环,跳出循环体。

for i in range(10):if i == 5:breakprint(i)  # 只打印0-4

continue语句

continue跳过当前迭代,直接进入下一次循环。

for i in range(10):if i % 2 == 0:continueprint(i)  # 只打印奇数

else子句

循环可以有一个可选的else块,它在循环正常完成(即不是由break终止)时执行。

for i in range(5):print(i)
else:print("循环正常完成")# 如果循环被break终止,else不会执行
for i in range(5):if i == 3:breakprint(i)
else:print("这不会被执行")

嵌套的循环结构

循环可以嵌套,即一个循环内部包含另一个循环。

# 打印乘法表
for i in range(1, 10):for j in range(1, i+1):print(f"{j}×{i}={i*j}", end="\t")print()  # 换行# 嵌套循环中的break和continue
for i in range(3):for j in range(3):if j == 1:break  # 只影响内层循环print(i, j)

循环结构的应用

例子1:判断素数

要求:输入一个大于 1 的正整数,判断它是不是素数。

提示:素数指的是只能被 1 和自身整除的大于 1 的整数。例如对于正整数 n,我们可以通过在 2 到 n−1 之间寻找有没有 n 的因子,来判断它到底是不是一个素数。当然,循环不用从 2 开始到 n−1 结束,因为对于大于 1 的正整数,因子应该都是成对出现的,所以循环到 n 就可以结束了。

"""
输入一个大于1的正整数判断它是不是素数
"""
num = int(input('请输入一个正整数: '))
end = int(num ** 0.5)
is_prime = True
for i in range(2, end + 1):if num % i == 0:is_prime = Falsebreak
if is_prime:print(f'{num}是素数')
else:print(f'{num}不是素数')
例子2:最大公约数

要求:输入两个大于 0 的正整数,求两个数的最大公约数。

提示:两个数的最大公约数是两个数的公共因子中最大的那个数。

"""
输入两个正整数求它们的最大公约数
"""
x = int(input('x = '))
y = int(input('y = '))
for i in range(x, 0, -1):if x % i == 0 and y % i == 0:print(f'最大公约数: {i}')break
例子3:猜数字游戏

要求:计算机出一个 1 到 100 之间的随机数,玩家输入自己猜的数字,计算机给出对应的提示信息“大一点”、“小一点”或“猜对了”,如果玩家猜中了数字,计算机提示用户一共猜了多少次,游戏结束,否则游戏继续。

"""
猜数字小游戏
"""
import randomanswer = random.randrange(1, 101)
counter = 0
while True:counter += 1num = int(input('请输入: '))if num < answer:print('大一点.')elif num > answer:print('小一点.')else:print('猜对了.')break
print(f'你一共猜了{counter}次.')

分支和循环结构实战

例子1:100以内的素数

说明:素数指的是只能被 1 和自身整除的正整数(不包括 1)

"""
输出100以内的素数
"""
for num in range(2, 100):is_prime = Truefor i in range(2, int(num ** 0.5) + 1):if num % i == 0:is_prime = Falsebreakif is_prime:print(num)

例子2:斐波那契数列

要求:输出斐波那契数列中的前 20 个数。

说明:斐波那契数列(Fibonacci sequence),通常也被称作黄金分割数列,是意大利数学家莱昂纳多·斐波那契(Leonardoda Fibonacci)在《计算之书》中研究理想假设条件下兔子成长率问题而引入的数列,因此这个数列也常被戏称为“兔子数列”。斐波那契数列的特点是数列的前两个数都是 1,从第三个数开始,每个数都是它前面两个数的和。按照这个规律,斐波那契数列的前 10 个数是:1, 1, 2, 3, 5, 8, 13, 21, 34, 55。斐波那契数列在现代物理、准晶体结构、化学等领域都有直接的应用。

"""
输出斐波那契数列中的前20个数
"""a, b = 0, 1
for _ in range(20):a, b = b, a + bprint(a)

例子3:寻找水仙花数

要求:找出 100 到 999 范围内的所有水仙花数。

提示:在数论中,水仙花数(narcissistic number)也被称为超完全数字不变数、自恋数、自幂数、阿姆斯特朗数,它是一个 N 位非负整数,其各位数字的 N 次方和刚好等于该数本身,例如: 153=13+53+33 ,所以 153 是一个水仙花数; 1634=14+64+34+44 ,所以 1634 也是一个水仙花数。对于三位数,解题的关键是将它拆分为个位、十位、百位,再判断是否满足水仙花数的要求,这一点利用 Python 中的//%运算符其实很容易做到。

"""
找出100到999范围内的水仙花数
"""
for num in range(100, 1000):low = num % 10mid = num // 10 % 10high = num // 100if num == low ** 3 + mid ** 3 + high ** 3:print(num)

例子4:百钱百鸡问题

说明:百钱百鸡是我国古代数学家张丘建在《算经》一书中提出的数学问题:鸡翁一值钱五,鸡母一值钱三,鸡雏三值钱一。百钱买百鸡,问鸡翁、鸡母、鸡雏各几何?翻译成现代文是:公鸡 5 元一只,母鸡 3 元一只,小鸡 1 元三只,用 100 块钱买一百只鸡,问公鸡、母鸡、小鸡各有多少只?

"""
百钱百鸡问题
"""
for x in range(0, 21):for y in range(0, 34):for z in range(0, 100, 3):if x + y + z == 100 and 5 * x + 3 * y + z // 3 == 100:print(f'公鸡: {x}只, 母鸡: {y}只, 小鸡: {z}只')"""
百钱百鸡问题2
"""
for x in range(0, 21):for y in range(0, 34):z = 100 - x - yif z % 3 == 0 and 5 * x + 3 * y + z // 3 == 100:print(f'公鸡: {x}只, 母鸡: {y}只, 小鸡: {z}只')

例子5:CRAPS赌博游戏

说明:CRAPS又称花旗骰,是美国拉斯维加斯非常受欢迎的一种的桌上赌博游戏。该游戏使用两粒骰子,玩家通过摇两粒骰子获得点数进行游戏。简化后的规则是:玩家第一次摇骰子如果摇出了 7 点或 11 点,玩家胜;玩家第一次如果摇出 2 点、3 点或 12 点,庄家胜;玩家如果摇出其他点数则游戏继续,玩家重新摇骰子,如果玩家摇出了 7 点,庄家胜;如果玩家摇出了第一次摇的点数,玩家胜;其他点数玩家继续摇骰子,直到分出胜负。为了增加代码的趣味性,我们设定游戏开始时玩家有 1000 元的赌注,每局游戏开始之前,玩家先下注,如果玩家获胜就可以获得对应下注金额的奖励,如果庄家获胜,玩家就会输掉自己下注的金额。游戏结束的条件是玩家破产(输光所有的赌注)。

"""
Craps赌博游戏
"""
import randommoney = 1000
while money > 0:print(f'你的总资产为: {money}元')# 下注金额必须大于0且小于等于玩家的总资产while True:debt = int(input('请下注: '))if 0 < debt <= money:break# 用两个1到6均匀分布的随机数相加模拟摇两颗色子得到的点数first_point = random.randrange(1, 7) + random.randrange(1, 7)print(f'\n玩家摇出了{first_point}点')if first_point == 7 or first_point == 11:print('玩家胜!\n')money += debtelif first_point == 2 or first_point == 3 or first_point == 12:print('庄家胜!\n')money -= debtelse:# 如果第一次摇色子没有分出胜负,玩家需要重新摇色子while True:current_point = random.randrange(1, 7) + random.randrange(1, 7)print(f'玩家摇出了{current_point}点')if current_point == 7:print('庄家胜!\n')money -= debtbreakelif current_point == first_point:print('玩家胜!\n')money += debtbreak
print('你破产了, 游戏结束!')
http://www.lryc.cn/news/572503.html

相关文章:

  • windows 11 安装和配置 WSL #1 Ubuntu
  • 30.all和any
  • 动态规划:01 背包(闫氏DP分析法)
  • python脚本间的相互调用
  • 磐基PaaS平台MongoDB组件SSPL许可证风险与合规性分析(上)
  • Git(三):分支管理
  • 达梦数据库锁超时问题
  • 使用Dagster资产工厂模式高效管理重复ETL任务
  • 识别网络延迟与带宽瓶颈
  • M1芯片macOS安装Xinference部署大模型
  • Datawhale 网络爬虫技术入门第2次笔记
  • QT6与VS下实现没有CMD窗口的C++控制台程序
  • 日本生活:日语语言学校-日语作文-沟通无国界(3)-题目:わたしの友達
  • 编程马拉松的定义、运作与发展
  • C语言标准I/O库详解:文件操作与缓冲区机制
  • Qt蓝图式技能编辑器状态机模块设计与实现
  • html实现登录与注册功能案例(不写死且只使用js)
  • 深入解析select模型:FD_SET机制与1024限制的终极指南
  • Linux系统远程操作和程序编译
  • 23.ssr和csr的对比?如何依赖node.js实现
  • [11-5]硬件SPI读写W25Q64 江协科技学习笔记(20个知识点)
  • 嵌入式编译工具链熟悉与游戏移植
  • 基于C#的Baumer相机二次开发教程
  • OpenSSL引擎 + PKCS11 + SoftHSM2认证
  • WHAT - React Native 开发 App 从 0 到上线全流程周期
  • 【嵌入式】鲁班猫玩法大全
  • 第1章: 伯努利模型的极大似然估计与贝叶斯估计
  • 软件工程(期末复习班)
  • 23种设计模式--简单工厂模式理解版
  • Arduino Nano 33 BLE Sense Rev 2开发板使用指南之【外设开发】