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

每日一题——Python实现PAT乙级1096 大美数(举一反三+思想解读+逐步优化)3千字好文


一个认为一切根源都是“自己不够强”的INTJ

个人主页:用哲学编程-CSDN博客
专栏:每日一题——举一反三
Python编程学习
Python内置函数

Python-3.12.0文档解读

目录

我的写法

时间复杂度分析

空间复杂度分析

总结

哲学和编程思想

1. 抽象与具体化

2. 迭代与递归

3. 分治法

4. 组合数学

5. 优化与效率

6. 模块化与复用

7. 防御性编程

8. 算法复杂度

9. 简洁与清晰

10. 面向对象与函数式编程

总结

举一反三

1. 抽象与模块化

2. 迭代与递归

3. 分治法

4. 组合数学

5. 优化与效率

6. 模块化与复用

7. 防御性编程

8. 算法复杂度

9. 简洁与清晰

10. 面向对象与函数式编程

总结


题目链接:https://pintia.cn/problem-sets/994805260223102976/exam/problems/type/7?problemSetProblemId=1478633632938655744&page=0

我的写法

import itertools
import mathdef factors(num):# 因数包括1和本身output = set()for i in range(1, int(math.sqrt(num)) + 1):if num % i == 0:output.add(i)output.add(num // i)return outputK = int(input())
nums = list(map(int, input().split()))for num in nums:num_factors = factors(num)#print(num_factors)if len(num_factors) >= 4:for combination in itertools.combinations(num_factors, 4):# 正整数 N 可以整除它的 4 个不同正因数之和,分清谁是除数被除数if sum(combination) %num == 0:#print(combination)print("Yes")breakelse:print("No")else:print("No")

时间复杂度分析

  1. 因数计算函数 factors(num):
    • 该函数的时间复杂度主要由遍历从1到 sqrt(num) 的整数决定,因此是 O(sqrt(num))。
  2. 主程序逻辑:
  • 对于每个正整数 num,计算因数的时间复杂度是 O(sqrt(num))。
  • 如果因数集合的长度大于等于4,则需要生成所有可能的4个因数的组合,并检查每个组合的和是否能被 num 整除。
  • 生成所有4个因数的组合的时间复杂度是 O(C_n^4),其中 n 是因数的数量。由于 n 通常远小于 num,这个复杂度可以近似为 O(n^4)。
  • 因此,对于每个正整数 num,总的时间复杂度是 O(sqrt(num) + n^4)。

空间复杂度分析

  1. 因数计算函数 factors(num):
    • 该函数使用了一个集合来存储因数,因此空间复杂度是 O(sqrt(num))。
  2. 主程序逻辑:
  • 主程序逻辑的空间复杂度主要由存储因数集合 num_factors 决定,因此是 O(sqrt(num))。
  • 此外,生成组合时会占用一些额外的空间,但由于组合的数量通常不会太大,这部分空间复杂度可以忽略不计。

总结

  • 时间复杂度:对于每个正整数 num,总的时间复杂度是 O(sqrt(num) + n^4)。
  • 空间复杂度:总的空间复杂度是 O(sqrt(num))。

这段代码在处理每个正整数时,能够有效地计算因数并检查是否存在满足条件的组合。然而,对于非常大的正整数,生成所有可能的4个因数的组合可能会导致较高的计算成本。


哲学和编程思想

这段代码体现了以下哲学和编程思想:

1. 抽象与具体化

  • 抽象:代码通过定义函数 factors(num) 来抽象出计算一个数的所有因数的过程。这种抽象使得代码更模块化,便于理解和维护。
  • 具体化:在主程序中,通过调用 factors(num) 函数并结合具体逻辑(如组合生成和条件判断)来解决具体问题。

2. 迭代与递归

  • 迭代:代码中使用 for 循环来遍历因数和组合,这是一种迭代思想。迭代通常比递归更直观且效率更高。

3. 分治法

  • 分治法:代码通过将问题分解为两个子问题:计算因数和检查组合。这种分治法使得问题更易于管理和解决。

4. 组合数学

  • 组合数学:代码使用 itertools.combinations 来生成所有可能的4个因数的组合。这体现了组合数学中的组合生成思想。

5. 优化与效率

  • 优化:代码在生成组合时,一旦找到满足条件的组合就立即返回结果,避免了不必要的计算,这是一种优化思想。
  • 效率:通过使用集合 set 来存储因数,避免了重复因数,提高了效率。

6. 模块化与复用

  • 模块化:代码通过定义独立的函数 factors(num),使得计算因数的过程可以被复用,体现了模块化编程思想。
  • 复用:主程序中多次调用 factors(num) 函数,体现了代码复用的原则。

7. 防御性编程

  • 防御性编程:代码在检查因数数量时,先判断因数数量是否大于等于4,这是一种防御性编程思想,确保程序在处理边界情况时不会出错。

8. 算法复杂度

  • 算法复杂度:代码在计算因数时,通过遍历到 sqrt(num) 来减少计算量,体现了对算法复杂度的考虑。

9. 简洁与清晰

  • 简洁:代码通过使用 itertools.combinations 和集合操作,使得代码简洁且易于理解。
  • 清晰:代码结构清晰,逻辑明确,易于阅读和维护。

10. 面向对象与函数式编程

  • 函数式编程:代码主要采用函数式编程风格,通过定义函数和使用高阶函数(如 itertools.combinations)来解决问题。
  • 面向对象:虽然代码主要采用函数式编程风格,但也可以通过将函数封装到类中来实现面向对象编程。

总结

这段代码体现了抽象与具体化、迭代与递归、分治法、组合数学、优化与效率、模块化与复用、防御性编程、算法复杂度、简洁与清晰以及函数式编程等多种哲学和编程思想。这些思想共同构成了代码的设计和实现基础。


举一反三

根据上述哲学和编程思想,以下是一些技巧,可以帮助你举一反三,更好地解决类似问题:

1. 抽象与模块化

  • 抽象化问题:将复杂问题分解为更小的、可管理的部分。例如,将计算因数的功能抽象为一个独立的函数。
  • 模块化设计:确保每个函数或模块只做一件事,并且做得好。这样可以使代码更易于测试、维护和复用。

2. 迭代与递归

  • 选择合适的循环结构:根据问题的性质选择使用 for 循环或 while 循环。通常,已知迭代次数时使用 for 循环,未知次数时使用 while 循环。
  • 递归思维:对于可以自然分解为更小子问题的问题,考虑使用递归。但要注意递归的深度和效率。

3. 分治法

  • 分解问题:将大问题分解为多个小问题,分别解决每个小问题,然后将结果合并。这有助于简化复杂问题的解决过程。

4. 组合数学

  • 利用组合工具:使用 itertools 库中的组合生成工具(如 combinations 和 permutations)来处理需要生成组合或排列的问题。

5. 优化与效率

  • 提前终止:在找到满足条件的解后立即返回,避免不必要的计算。
  • 选择合适的数据结构:根据问题的需求选择合适的数据结构,如使用集合 set 来避免重复元素。

6. 模块化与复用

  • 代码复用:设计可复用的函数和模块,避免重复代码。
  • 库的使用:利用现有的库和工具,如 math 和 itertools,来提高开发效率。

7. 防御性编程

  • 边界检查:在处理输入数据时,进行必要的边界检查,确保程序在异常情况下也能正常运行。
  • 错误处理:使用异常处理机制来捕获和处理可能的错误。

8. 算法复杂度

  • 选择合适的算法:根据问题的规模和性质选择合适的算法,考虑时间复杂度和空间复杂度。
  • 优化算法:对算法进行优化,减少不必要的计算和存储。

9. 简洁与清晰

  • 代码风格:保持代码风格一致,使用有意义的变量名和函数名,使代码易于理解。
  • 注释和文档:添加必要的注释和文档,帮助他人理解代码。

10. 面向对象与函数式编程

  • 选择编程范式:根据问题的性质选择合适的编程范式。函数式编程适合处理数据转换和计算密集型任务,而面向对象编程适合处理复杂的数据结构和对象交互。
  • 混合使用:在必要时,可以将函数式编程和面向对象编程结合起来,发挥各自的优势。

总结

通过运用这些技巧,可以更好地理解和解决类似问题,提高编程能力和代码质量。不断实践和总结经验,将有助于在编程道路上不断进步。

相关文章:

每日一题——Python实现PAT乙级1096 大美数(举一反三+思想解读+逐步优化)3千字好文

一个认为一切根源都是“自己不够强”的INTJ 个人主页:用哲学编程-CSDN博客专栏:每日一题——举一反三Python编程学习Python内置函数 Python-3.12.0文档解读 目录 我的写法 时间复杂度分析 空间复杂度分析 总结 哲学和编程思想 1. 抽象与具体化 …...

无锁编程——从CPU缓存一致性讲到内存模型(1)

一.前言 1.什么是有锁编程,什么是无锁编程? 在编程中,特别是在并发编程的上下文中,“无锁”和“有锁”是描述线程同步和资源访问控制的两种不同策略。有锁(Locked): 有锁编程是指使用锁(例如互…...

C++编程(七)继承

文章目录 一、继承(一)概念(二)语法格式(三)通过子类访问父类中的成员1. 类内2. 类外 (四)继承中的特殊成员函数1. 构造函数2. 析构函数3. 拷贝构造函数4. 拷贝赋值函数 二、多重继承…...

【ACM_2023】3D Gaussian Splatting for Real-Time Radiance Field Rendering

【ACM_2023】3D Gaussian Splatting for Real-Time Radiance Field Rendering 一、前言Abstract1 INTRODUCTION2 RELATED WORK2.1 Traditional Scene Reconstruction and Rendering2.2 Neural Rendering and Radiance Fields2.3 Point-Based Rendering and Radiance Fields 3 O…...

【TB作品】atmega16 计算器,ATMEGA16单片机,Proteus仿真

实验报告:基于ATmega16单片机的简易计算器设计 1. 实验背景 计算器是日常生活和工作中不可或缺的工具,通过按键输入即可实现基本的四则运算。通过本实验,我们将利用ATmega16单片机、矩阵键盘和LCD1602显示屏,设计并实现一个简易…...

C++的IO流操作

文章目录 C语言的输入与输出流是什么CIO流C标准IO流C文件IO流二进制读写文本读写 stringstream的简单介绍 C语言的输入与输出 C语言的输入与输出 C语言中我们用到的最频繁的输入输出方式就是scanf()与printf()。 scanf(): 从标准输入设备(键盘)读取数据,并将值存放…...

MacOS升级指定Python版本的pip

场景: 系统默认是Python2.7,已经通过brew install python3.11 python3.12安装了多个版本的Python 执行:pip --version pip 24.1 from /Users/mac10.12/Library/Python/3.11/lib/python/site-packages/pip (python 3.11) 用的是Python3.11…...

音频Balance源码总结

音频Balance源码总结 何为音频Balance? 顾名思义,Balance及平衡,平衡也就是涉及多方,音频左右甚至四通道,调节所有通道的音量比,使用户在空间内听到各个通道的音频大小不一,好似置身于真实环境…...

CesiumJS【Basic】- #043 绘制脉冲线(Entity方式)- 需要自定义着色器

文章目录 绘制脉冲线(Entity方式)- 需要自定义着色器1 目标2 代码2.1 main.ts3 资源文件绘制脉冲线(Entity方式)- 需要自定义着色器 1 目标 使用Entity方式绘制脉冲线 2 代码 2.1 main.ts import * as Cesium from cesium;const viewer = new Cesium.Viewer(cesiumCont…...

Linux命令 wc(word count)-l(lines)用于统计文件中的行数。

文章目录 1、wc -l2、实战3、wc --help 1、wc -l 在命令 wc -l 中,-l 的英文全称是 lines。这个选项用于指定 wc(word count,单词计数)命令来统计文件的行数。 例如,当你运行 wc -l load_user_100w_sort.sql 时&…...

数据结构 - C/C++ - 链表

目录 结构特性 内存布局 结构样式 结构拓展 单链表 结构定义 节点关联 插入节点 删除节点 常见操作 双链表 环链表 结构容器 结构设计 结构特性 线性结构的存储方式 顺序存储 - 数组 链式存储 - 链表 线性结构的链式存储是通过任意的存储单元来存储线性…...

sheng的学习笔记-AI-高斯混合模型(GMM)

AI目录:sheng的学习笔记-AI目录-CSDN博客 需要学习前置知识: 聚类,可参考 sheng的学习笔记-AI-聚类(Clustering)-CSDN博客 EM算法,可参考 sheng的学习笔记-AI-EM算法-CSDN博客 贝叶斯,可参考 sheng的学习笔记-AI-…...

OFDM的缺点与关键技术

子载波间干扰英文简写ICI,ICI可能由各种原因引起 在多径信道中,CP小于最大附加时延时收发系统载波频率偏差和采样偏差收发系统相对移动,存在多普勒频移 ICI是制约OFDM系统性能的主要重要因素之一 对频率偏差敏感----->同步技术&#xff0…...

电脑录音软件哪个好?7款录制音频工具大盘点,赶快学起来!(2024)

也许你渴望提取你最喜欢的节目的背景音乐,或者你希望录制自己的声音制作教程。如果是这样,你就需要一款优秀的电脑录音软件,来帮助你捕捉任何你想要的声音,而且不会损失音质。目前市场上存在着大量的录制音频工具,面对…...

【Android面试八股文】你说你使用Leakcanary进行内存泄漏检测,那你能说一说Leakcanary的原理吗?

文章目录 一、 Java四大引用二、 LeakCanary示例工作机制注意事项三、 Leakcanary的原理四、 Leakcanary的源码分析LeakCanary#Install创建RefWatcherAndroidRefWatcherBuilder#buildAndInstall监听Activity的引用 : ActivityRefWatcher检查引用Dump Heap解析hprof定位泄露的引…...

蒂升电梯职业性格和Verify认知能力SHL测评答题攻略及薪资待遇解密!

​一、蒂升电梯职业性格和认知能力测评考什么 您好!蒂升电梯公司邀请您参加的OPQ职业性格测评和Verify认知能力测评是两种常见的评估工具,用于帮助了解个人的职场性格特点和认知能力。 OPQ职业性格测评 这是一种性格测试,通常用于评估个人在…...

window上部署sql server改动端口、和sqlserver的一些还原、批量插入存储过程的命令

1.端口的查看和启动 --windows上安装上sql server数据库后,搜索界面搜索sql,会出现配置管理器,点击进入 --进入后再次选择配置管理器 2. sqlserver数据库还原图形化 sqlserver还原数据库时会使数据库进入一个restore的还原状态,…...

【单片机与嵌入式】stm32串口通信入门

一、串口通信/协议 (一)串口通信简介 串口通信是一种通过串行传输方式在电子设备之间进行数据交换的通信方式。它通常涉及两条线(一条用于发送数据,一条用于接收数据),适用于各种设备,从微控制…...

启动Redis服务器

名人说:一点浩然气,千里快哉风。 ——苏轼 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 目录 一、在 Linux 或 macOS 上启动 Redis二、在 Windows 上启动 Redis三、配置 Redis 为服务启动&…...

uniapp中使用threejs加载几何体

我的建议是使用这个库 https://github.com/deepkolos/three-platformize 为什么?我试了uniapp推荐的和threejs-miniprogram这个小程序官方库,都加载不出来我的obj模型。所有我推荐不要用obj模型最好,挺多都支持GLTF模型的,但是我不…...

go-zero微服务入门案例

一、go-zero微服务环境安装 1、go-zero脚手架的安装 go install github.com/zeromicro/go-zero/tools/goctllatest2、etcd的安装下载地址根据自己电脑操作系统下载对应的版本,具体的使用自己查阅文章 二、创建一个user-rpc服务 1、定义user.proto文件 syntax &qu…...

网络寻路--图论

所以我们固定题中M条边&#xff08;因为这M条一定联通&#xff09; P8605 [蓝桥杯 2013 国 AC] 网络寻路 - 洛谷 #include<bits/stdc.h> using namespace std; #define N 100011 typedef long long ll; typedef pair<int,int> pii; int n,m; int d[N],u[N],v[N]…...

论文解读:Locating and Editing Factual Associations in GPT(ROME)

论文发表于人工智能顶会NeurIPS(原文链接)&#xff0c;研究了GPT(Generative Pre-trained Transformer)中事实关联的存储和回忆&#xff0c;发现这些关联与局部化、可直接编辑的计算相对应。因此&#xff1a; 1、开发了一种因果干预方法&#xff0c;用于识别对模型的事实预测起…...

数论——同余问题全家桶3 __int128和同余方程组

数论——同余问题全家桶3 __int128和同余方程组 快速读写和__int128快速读写__int128 中国剩余定理和线性同余方程组中国剩余定理(CRT)中国剩余定理OJ示例模板题曹冲养猪 - 洛谷模板题猜数字 - 洛谷 扩展中国剩余定理扩展中国剩余定理OJ示例模板题扩展中国剩余定理&#xff08;…...

基于SFC的windows系统损坏修复程序

前言 在平时使用Windows操作系统时会遇到很多因为系统文件损坏而出现的错误 例如:系统应用无法打开 系统窗口(例如开始菜单)无法使用 电脑蓝屏或者卡死 是如果想要修复很多人只能想到重装系统。但其实Windows有一个内置的系统文件检查器可以修复此类错误。 原理 SFC命令…...

微服务网关SpringCloudGateway+SaToken鉴权

目录 概念 前置知识回顾 拿到UserInfo 用于自定义权限和角色的获取逻辑 最后进行要进行 satoken 过滤器全局配置 概念 做权限认证的时候 我们首先要明确两点 我们需要的角色有几种 我们需要的权限有几种 角色 分两种 ADMIN 管理员 &#xff1a;可管理商品 CUSTIOMER 普通…...

固态继电器与驱动隔离器:电力系统的守护者

在电力系统中&#xff0c; 固态继电器合驱动隔离器像两位“电力守护神”&#xff0c;默默地确保电力设备的安全与稳定运行。它们通过高效、可靠的性能&#xff0c;保障了电力设备在各种环境下的正常工作。 固态继电器是电力控制中的关键组成部分&#xff0c;利用半导体器件来实…...

uni-app 如何实现选择和上传非图像、视频文件?

在 uni-app 中实现选择和上传非图像、视频文件&#xff0c;可根据不同端&#xff08;App、H5、小程序&#xff09;的特点&#xff0c;采用以下方法&#xff1a; 一、通用思路&#xff08;多端适配优先推荐&#xff09; 借助 uni.chooseFile 选择文件&#xff0c;再用 uni.upl…...

李沐《动手学深度学习》d2l安装教程

文章目录 最新回答报错提醒安装对应版本安装C工具和Windows SDK 最新回答 安装旧版本即可 pip install d2l0.17.0 WARNING: Ignoring invalid distribution -pencv-python (e:\python3.10\lib\site-packages) Looking in indexes: https://pypi.tuna.tsinghua.edu.cn/simple C…...

centos7升级glibic-2.28

centos7升级glibic-2.28 最近使用trae连接服务器的时候&#xff0c;提示远程系统不兼容: Trae CN需要glibc 2.28或更高版本。检测到的版本: 2.17。下面是升级步骤。centos7默认的glibc不支持node v18及以上。 1、进入/home/download目录(没有download&#xff0c;则新建一个)…...