Python中的程序逻辑经典案例详解

2023-12-17 03:28

本文主要是介绍Python中的程序逻辑经典案例详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我的博客

文章首发于公众号:小肖学数据分析

Python作为一种强大的编程语言,以其简洁明了的语法和强大的标准库,成为了理想的工具来构建这些解决方案。

本文将通过Python解析几个经典的编程问题。

经典案例

水仙花数

问题描述:水仙花数指的是一个n位数,它的各位数字的n次幂之和等于它自身。例如,对于三位数153,其满足1^3 + 5^3 + 3^3 = 153,因此它是一个水仙花数。

Python代码实现

def is_narcissistic(number):# 将数字转换成字符串,便于后续遍历其各个位上的数字digits = [int(d) for d in str(number)]# 比较原数和其各位数字幂次和是否相等,从而判断是否为水仙花数return sum(d**len(digits) for d in digits) == number# 检索并打印出所有三位水仙花数
narcissistic_numbers = [num for num in range(100, 1000) if is_narcissistic(num)]
print("水仙花数:", narcissistic_numbers)
百钱百鸡

问题描述:古中国数学家提出的问题。现有100文钱,需要买100只鸡。其中公鸡每只5文钱,母鸡每只3文钱,小鸡3只1文钱。如何买?

Python代码实现

def calculate_hundred_chickens():solutions = []# 遍历公鸡的可能数目for roosters in range(21):  # 公鸡最多买20只# 遍历母鸡的可能数目for hens in range(34):  # 母鸡最多买33只# 通过总数和总金额限制计算小鸡数目chicks = 100 - roosters - hensif 5 * roosters + 3 * hens + chicks / 3 == 100:solutions.append((roosters, hens, chicks))return solutions# 输出可能的买鸡方案
print("百钱买百鸡的方案:", calculate_hundred_chickens())
Craps骰子游戏

问题描述:玩家掷两个骰子,如果第一次掷出7点或11点则玩家胜,掷出2点、3点或12点则庄家胜,其他点数玩家继续掷骰,直到点数重复则玩家胜,掷出7点则庄家胜。

Python代码实现

from random import randrangedef roll_dice():# 模拟掷骰子,返回两个骰子点数之和return randrange(1, 7) + randrange(1, 7)def play_craps():# 第一轮掷骰子结果point = roll_dice()# 玩家胜利的点数wins = {7, 11}# 庄家胜利的点数losses = {2, 3, 12}# 根据第一轮的结果判断胜负if point in wins:return "玩家胜利!"elif point in losses:return "庄家胜利!"# 若未分出胜负,继续游戏while True:roll = roll_dice()if roll == point:return "玩家胜利!"elif roll == 7:return "庄家胜利!"# 模拟游戏并输出结果
print("Craps赌博游戏结果:", play_craps())

进阶练习题

斐波那契数列

问题描述:斐波那契数列是这样一个数列,除前两个数字外,每个数字都是前两个数字之和。求斐波那契数列的第n项。

Python代码实现

from functools import lru_cache@lru_cache(maxsize=None)
def fibonacci(n):# 基准情况处理if n in (0, 1):return n# 递归求解斐波那契数列的前两项return fibonacci(n-1) + fibonacci(n-2)# 计算前20个斐波那契数列数并打印
for i in range(20):print(fibonacci(i), end=" ")
print()
完美数

问题描述:一个等于其所有真因子(即除了自身以外的约数)之和的数称为完美数。求不超过10000的所有完美数。

Python代码实现

def is_perfect_number(n):# 计算除自身外所有因子的和factors = [1] + [i for i in range(2, int(n**0.5)+1) if n % i == 0]# 检查因子和是否等于原数return sum(factors) + sum(n // i for i in factors if i != 1 and n // i != i) == n# 寻找并打印所有完美数
print([n for n in range(2, 10001) if is_perfect_number(n)])
素数生成

问题描述:素数是只能被1和它自己整除的大于1的数。求不超过100的所有素数。

Python代码实现

def eratosthenes_sieve(limit):# 创建一个布尔数组,初始假设所有数字都是素数primes = [True] * limit# 用埃拉托斯特尼筛法筛选素数for num in range(2, int(limit**0.5) + 1):if primes[num]:# 将num的倍数标记为非素数primes[num*num:limit:num] = [False] * ((limit - num*num - 1) // num + 1)# 筛选并返回素数列表return [num for num in range(2, limit) if primes[num]]# 打印100以内的素数
print(eratosthenes_sieve(100))

结语

掌握构建程序的逻辑,就像攀登一座山峰。在这个过程中,我们不断地解决问题,逐步攀升,直到最终达到顶峰。让我们享受编程带来的挑战和乐趣。

这篇关于Python中的程序逻辑经典案例详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/502906

相关文章

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

从基础到高级详解Python数值格式化输出的完全指南

《从基础到高级详解Python数值格式化输出的完全指南》在数据分析、金融计算和科学报告领域,数值格式化是提升可读性和专业性的关键技术,本文将深入解析Python中数值格式化输出的相关方法,感兴趣的小伙... 目录引言:数值格式化的核心价值一、基础格式化方法1.1 三种核心格式化方式对比1.2 基础格式化示例

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

Ubuntu如何升级Python版本

《Ubuntu如何升级Python版本》Ubuntu22.04Docker中,安装Python3.11后,使用update-alternatives设置为默认版本,最后用python3-V验证... 目China编程录问题描述前提环境解决方法总结问题描述Ubuntu22.04系统自带python3.10,想升级

Python自动化处理PDF文档的操作完整指南

《Python自动化处理PDF文档的操作完整指南》在办公自动化中,PDF文档处理是一项常见需求,本文将介绍如何使用Python实现PDF文档的自动化处理,感兴趣的小伙伴可以跟随小编一起学习一下... 目录使用pymupdf读写PDF文件基本概念安装pymupdf提取文本内容提取图像添加水印使用pdfplum