当前位置: 首页 > 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('你破产了, 游戏结束!')

相关文章:

  • WPF xaml 中设置ResourceDictionary中的全局变量
  • 【机械视觉】Halcon—【十五、一维码(条形码)和二维码识别】
  • 【八股消消乐】构建微服务架构体系—保证服务高可用
  • 华为OD机试_2025 B卷_玩牌高手(Python,100分)(附详细解题思路)
  • 从C++编程入手设计模式——装饰器模式
  • Dify 推出全新版本!Dify-v1.4.3本地部署教程:开发效率飙升,快速打造 AI 应用!
  • Mysql5.7 自动备份恢复示例
  • 《Kubernetes》Pod详解+Pod控制器
  • 用“Gemini 2.0 Flash Preview Image Generation”模型修改图片,有哪些常用的提示词和方法
  • 计算机网络零基础完全指南
  • 九尾狐编程语言新算法“超维时空演算体”
  • 加密货币:什么是稳定币?
  • 《Go语言圣经》结构体
  • 宽度优先遍历(bfs)(3)——最小路径问题
  • RTSP播放器低延迟实践:一次对毫秒级响应的技术探索
  • SpringBoot扩展——发送邮件!
  • flink的多种部署模式
  • Kaggle-Plant Seedlings Classification-(多分类+CNN+图形处理)
  • 解决“在EFI系统上,Windows只能安装到GPT磁盘“错误
  • DINO-R1:激励推理能力的视觉基础模型
  • 上海企业网站/发布新闻最快的网站
  • cf域名免费注册/企业seo关键字优化
  • 免费网站怎么建/简阳seo排名优化培训
  • 网站开发 程序开发阶段/营销型网站外包
  • 淘宝店铺做网站收录/网站安全检测工具
  • 政府网站建设方面存在的问题/常用的网络推广方法有