分支和循环结构的重要性不言而喻,它是构造程序逻辑的基础。
一、程序的结构控制
单分支结构:
单分支结构是分支结构中最简单的一种方式,单分支结构只需要判断一个条件,根据这个条件是否成立来决定是否执行一段语句。
二分支结构:
二分支结构是根据条件判断的不同而选择不同执行路径的一种分支结构,二分支结构也只需要判断一个条件,根据这个条件来决定执行的语句块,成立执行if中的指令,不成立执行else中的语句。
多分支结构:
多分支结构是根据不同条件来选择语句块运行的一种分支结构,分支结构需要判断多个条件,根据判断当前条件是否成立来决定是否执行当前语句块,当所有条件都不成立时,执行else后的语句块。
二、分支和循环结构真题训练
1.寻找水仙花数。
水仙花数也被称为超完全数字不变数、自恋数、自幂数、阿姆斯特朗数,它是一个3位数,该数字每个位上数字的立方之和正好等于它本身。
这个题目的关键是将一个三位数拆分为个位、十位、百位,这一点利用Python中的//
(整除)和%
(求模)运算符其实很容易做到:
# @Time : 2024/3/9 14:07# @Author : 是Dream呀# @File : 12345.pyfor num in range(100, 1000): low = num % 10 mid = num // 10 % 10 high = num // 100 if num == low ** 3 + mid ** 3 + high ** 3: print(num)
2.正整数的反转
上面利用//
和%
拆分一个数的小技巧在写代码的时候还是很常用的。我们要将一个不知道有多少位的正整数进行反转,例如将12345
变成54321
,也可以利用这两个运算来实现,代码如下所示。
# @Time : 2024/3/9 14:07# @Author : 是Dream呀# @File : 12345.pynum = int(input('num = '))reversed_num = 0while num > 0: reversed_num = reversed_num * 10 + num % 10 num //= 10print(reversed_num)
3.百钱百鸡问题。
百钱百鸡是我国古代数学家张丘建
在《算经》一书中提出的数学问题:鸡翁一值钱五,鸡母一值钱三,鸡雏三值钱一。百钱买百鸡,问鸡翁、鸡母、鸡雏各几何?翻译成现代文是:公鸡5元一只,母鸡3元一只,小鸡1元三只,用100块钱买一百只鸡,问公鸡、母鸡、小鸡各有多少只?
# @Time : 2024/3/9 14:07# @Author : 是Dream呀# @File : 12345.py# 假设公鸡的数量为x,x的取值范围是0到20for x in range(0, 21): # 假设母鸡的数量为y,y的取值范围是0到33 for y in range(0, 34): z = 100 - x - y if 5 * x + 3 * y + z // 3 == 100 and z % 3 == 0: print(f'公鸡: {x}只, 母鸡: {y}只, 小鸡: {z}只')
上面使用的方法叫做穷举法,也称为暴力搜索法,这种方法通过一项一项的列举备选解决方案中所有可能的候选项并检查每个候选项是否符合问题的描述,最终得到问题的解。这种方法看起来比较笨拙,但对于运算能力非常强大的计算机来说,通常都是一个可行的甚至是不错的选择,只要问题的解存在就能够找到它。
4.CRAPS赌博游戏。
CRAPS又称花旗骰,是美国拉斯维加斯非常受欢迎的一种的桌上赌博游戏。该游戏使用两粒骰子,玩家通过摇两粒骰子获得点数进行游戏。简化后的规则是:玩家第一次摇骰子如果摇出了7点或11点,玩家胜;玩家第一次如果摇出2点、3点或12点,庄家胜;玩家如果摇出其他点数则玩家继续摇骰子,如果玩家摇出了7点,庄家胜;如果玩家摇出了第一次摇的点数,玩家胜;其他点数玩家继续摇骰子,直到分出胜负。
Craps赌博游戏
我们设定游戏开始时玩家有1000元的赌注
游戏结束的条件是玩家破产(输光所有的赌注)
from random import randintmoney = 1000while money > 0: print(f'你的总资产为: {money}元') go_on = False # 下注金额必须大于0小于等于玩家总资产 while True: debt = int(input('请下注: ')) if 0 < debt <= money: break # 第一次摇色子 # 用1到6均匀分布的随机数模拟摇色子得到的点数 first = randint(1, 6) + randint(1, 6) print(f'\n玩家摇出了{first}点') if first == 7 or first == 11: print('玩家胜!\n') money += debt elif first == 2 or first == 3 or first == 12: print('庄家胜!\n') money -= debt else: go_on = True # 第一次摇色子没有分出胜负游戏继续 while go_on: go_on = False current = randint(1, 6) + randint(1, 6) print(f'玩家摇出了{current}点') if current == 7: print('庄家胜!\n') money -= debt elif current == first: print('玩家胜!\n') money += debt else: go_on = Trueprint('你破产了, 游戏结束!')
5.斐波那契数列。
斐波那契数列(Fibonacci sequence),通常也被称作黄金分割数列,是意大利数学家莱昂纳多·斐波那契(Leonardoda Fibonacci)在《计算之书》中研究在理想假设条件下兔子成长率问题而引入的数列,因此这个数列也常被戏称为“兔子数列”。斐波那契数列的特点是数列的前两个数都是1,从第三个数开始,每个数都是它前面两个数的和,按照这个规律,斐波那契数列的前10个数是:1, 1, 2, 3, 5, 8, 13, 21, 34, 55
。斐波那契数列在现代物理、准晶体结构、化学等领域都有直接的应用。
输出斐波那契数列前20个数
6.打印100以内的素数。
素数指的是只能被1和自身整除的正整数(不包括1)。
# @Time : 2024/3/9 14:07# @Author : 是Dream呀# @File : 12345.pyfor num in range(2, 100): # 假设num是素数 is_prime = True # 在2到num-1之间找num的因子 for factor in range(2, num): # 如果找到了num的因子,num就不是素数 if num % factor == 0: is_prime = False break # 如果布尔值为True在num是素数 if is_prime: print(num)
文末免费送书:Vue.js 快速入门实战 前端开发进阶实战
Vue.js 快速入门实战以Vue.js的知识点为基础,结合TypeScript的使用,循序渐进地介绍了Vue.js 3.0(简称Vue3)的知识点和实战技巧,可以帮助零基础的读者掌握独立开发项目和部署项目上线的技术。全书共14章,包括Vue.js概述、搭建开发环境、Vue.js组合式API、Vue.js的模板语法、Vue.js的计算属性和侦听器、Vue.js中class和style的绑定、Vue.js的表单开发、Vue.js的组件开发、Vue.js的网络请求、Vue.js的状态管理、Vue.js的路由管理、Vue的项目部署、在线招聘网站开发实战以及招聘网站后台管理系统开发实战。
Vue.js 快速入门实战图文并茂、结构清晰、用例丰富、实例典型、实战性强。随书附赠案例代码和教学视频,是一本典型的从入门到精通类的实战学习手册,适合软件开发人员、计算机专业大学生、对Vue编程感兴趣且喜欢动手实操的爱好者和专业前端开发人员阅读。
抽奖方式
抽奖方式: 评论区随机抽取9位小伙伴免费送出!
参与方式: 关注博主、点赞、收藏、评论区评论“人生苦短,我用Python!”(切记要点赞+收藏,否则抽奖无效,每个人最多评论三次!)
活动截止时间: 2024-3-25 10:00:00
京东: 购买链接传送门
😄😄😄名单公布方式: 下期活动开始将在评论区和私信一并公布,中奖者请三天内提供信息😄😄😄