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 - hens
            if 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 randrange

def 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))

结语

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/250803.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

三勾商城新功能-电子面单发货

商家快递发货时可以选择在线下单,在线获取和打印电子面单。免去手写面单信息以及避免填写运单号填错,系统会自动填写对应发货商品的运单信息 快递100电子面单1、进入快递100,点击登录 2、登录成功后,点击“电子面单与云打印” 3、进入电子面单与云打印后…

Druid-spring-boot-starter源码阅读-其余组件自动装配

前面我们看完了整个DruidDataSource初始化流程,但是其实Druid除了最核心的数据源之外,还有其他需要自动配置的,细心的人可能看到了,就是利用Import注解导入的四个类。 DruidFilterConfiguration public class DruidFilterConfigu…

解决:TypeError: write() argument must be str, not tuple

解决:TypeError: write() argument must be str, not tuple 文章目录 解决:TypeError: write() argument must be str, not tuple背景报错问题报错翻译报错位置代码报错原因解决方法今天的分享就到此结束了 背景 在使用之前的代码时,报错&…

缓存的定义及重要知识点

文章目录 缓存的意义缓存的定义缓存原理缓存的基本思想缓存的优势缓存的代价 缓存的重要知识点 缓存的意义 在互联网高访问量的前提下,缓存的使用,是提升系统性能、改善用户体验的唯一解决之道。 缓存的定义 缓存最初的含义,是指用于加速 …

联邦边缘学习中的知识蒸馏综述

联邦边缘学习中的知识蒸馏综述 移动互联网的快速发展伴随着智能终端海量用户数据的产生。如何在保护数据隐私的前提下,利用它们训练出性能优异的机器学习模型,一直是业界关注的难点。为此,联邦学习应运而生,它允许在终端本地训练并协同边缘服务器进行模型聚合来实现分布式机器…

下午好~ 我的论文【yolo1~4】(第二期)

写在前面:本来是一期的,我看了太多内容了,于是分成三期发吧 TAT (捂脸) 文章目录 YOLO系列v1v2v3v4 YOLO系列 v1 You Only Look Once: Unified, Real-Time Object Detection 2015 ieee computer society 12.3 CCF-C…

网站提示“不安全”

当你在浏览网站时,有时可能会遇到浏览器提示网站不安全的情况。这通常是由于网站缺乏SSL证书所致。那么,从SSL证书的角度出发,我们应该如何解决这个问题呢? 首先,让我们简单了解一下SSL证书。SSL证书是一种用于保护网站…

论文阅读——Semantic-SAM

Semantic-SAM可以做什么: 整合了七个数据集: 一般的分割数据集,目标级别分割数据集:MSCOCO, Objects365, ADE20k 部分分割数据集:PASCAL Part, PACO, PartImagenet, and SA-1B The datasets are SA-1B, COCO panopt…

Grafana Loki 快速尝鲜

Grafana Loki 是一个支持水平扩展、高可用的聚合日志系统,跟其他的聚合日志系统不同,Loki只对日志的元数据-标签进行索引,日志数据会被压缩并存储在对象存储中,甚至可以存储在本地文件系统中,能够有效降低成本&#xf…

Python基础09-学生管理系统

零、文章目录 Python基础09-学生管理系统 1、学员管理系统功能概述 (1)最终效果图 (2)功能概述 需求:进入系统显示系统功能界面,功能如下: 【1】添加学员信息->add_student【2】删除学员…

Python基础01-环境搭建与输入输出

零、文章目录 Python基础01-环境搭建与输入输出 1、Python概述 (1)为什么要学习Python 技术趋势:Python自带明星属性,热度稳居编程语言界前三 简单易学:开发代码少,精确表达需求逻辑;33个关…

SDN之Python编程创建多数据中心网络

文章目录 1.拓扑结构2.具体步骤 1.拓扑结构 通过python编程创建一个包含2台核心交换机、4台汇聚交换机、8台边缘交换机和16台主机的网络拓扑,如图示: 2.具体步骤 首先ctrlaltT(或右键)打开终端,在/home/shy/minine…

关于学习计算机的心得与体会

也是隔了一周没有发文了,最近一直在准备期末考试,后来想了很久,学了这么久的计算机,这当中有些收获和失去想和各位正在和我一样在学习计算机的路上的老铁分享一下,希望可以作为你们碰到困难时的良药。先叠个甲&#xf…

Ansys Lumerical | 采用一维光栅的出瞳扩展器的优化

附件下载 联系工作人员获取附件 本文演示了一种仿真方法,并举例说明了使用一维光栅的出瞳扩张器(EPE)系统的优化示例。 在此工作流程中,我们使用 Lumerical 构建光栅模型,并使用 RCWA 求解器模拟其响应。完整的EPE系…

云演CTF Blog

1、啥也搞不了,扫目录。出来个console 2、有显示锁掉了 3、抓包,改返回包 改成true,放包 不好意思,不会了,哈哈哈哈哈哈哈哈哈 你会的话,请告诉我,大佬

MyBatis问题记录

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): 原因:标注了MapperScan 在 Spring Boot 中,MapperScan 注解用于扫描 MyBatis Mapper 接口的包路径,并将其注册为 Spring Bean。在一些简单的情况下&…

基于SSM的图书馆预约座位系统的设计与实现(部署+源码+LW)

项目描述 临近学期结束,还是毕业设计,你还在做java程序网络编程,期末作业,老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。今天给大家介绍一篇基于SSM的图书馆预约座位…

【AI】YOLO学习笔记

作为经典的图像识别网络模型,学习YOLO的过程也是了解图像识别的发展过程,对于初学者来说,也可以了解所采用算法的来龙去脉,构建解决问题的思路。 1.YOLO V1 论文地址:https://arxiv.org/abs/1506.02640 YOLO&#x…

Spring框架知识总结

目录 1、Spring框架有哪些设计模式? 2、介绍一下Spring框架和SpringBoot框架? 3、介绍一下SpringBoot具有哪些功能模块? 4、Spring用到了什么组件? 5、什么是IoC? 什么是AOP? 6、SpringBoot运行原理&#xff1…

YOLOv8-Seg改进:轻量化卷积设计 | DualConv双卷积魔改v8结构

🚀🚀🚀本文改进: DualConv双卷积魔改v8结构,达到轻量化的同时并能够实现小幅涨点 🚀🚀🚀YOLOv8-seg创新专栏:http://t.csdnimg.cn/KLSdv 学姐带你学习YOLOv8,从入门到创新,轻轻松松搞定科研; 1)手把手教你如何训练YOLOv8-seg; 2)模型创新,提升分割性能…