蓝桥杯python组--基础训练---2、#一个数如果恰好等于它的因子之和,这个数就称为“完数”,;例如:6=1+2+3,找出1000以内的

本文主要是介绍蓝桥杯python组--基础训练---2、#一个数如果恰好等于它的因子之和,这个数就称为“完数”,;例如:6=1+2+3,找出1000以内的,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 题目
  • 思路1
    • 结果
  • 思路2
    • 结果
  • 思路3
    • 结果
  • 思路4
    • 结果
  • 思路5
    • 结果
  • 思路6
    • 结果
  • 思路7
    • 结果
  • 思路8
    • 结果
  • 思路9
    • 结果
  • 总结

题目

找出n以内的完数,如1000以内。
完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数。它所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于它本身。
例如:6=1+2+3;28=1+2+4+7+14;…

思路1

# 循环输出11000之间的数  range():含头不含尾
for i in range(1,1001):# 此时i代表1-1000之间所有的数# 定义和的初始值sum = 0# 构造数字的因子for j in range(1,i):#     因子:能被i整除的是i的因子if i % j == 0:#     只要是i的因子那么就相加sum += j# 如果 因子相加的和  等于i本身那么这个数就是完数if sum == i:print(f"{i}是完数")

或者也可以这样写

for i in range(1,1000):s = []for j in range(1,i):if i%j == 0:s.append(j)if sum(s) == i:print(i)

结果

在这里插入图片描述

思路2

from functools import reduce
def sum(a,b):return a+b
for i in range(2,1001):l = [1]for j in range(2,int(i/2+1)):if i%j==0:l.append(j)if i == reduce(sum,l):print(i)print(l)

结果

在这里插入图片描述

思路3

count = 0
for i in range(1,1001):list1 = []for j in range(1,i):if i%j==0:list1.append(j)if sum(list1)==i:#sum函数求和count +=1print('%d是完数,因子是'%i,list1)
print('1000以内的完数总共有%d个'%count)

结果

在这里插入图片描述

思路4

count  = 0
for i in range(2,1000):s = 0for j in range(1, i):if(i%j==0):s=s+jif(s==i):count = count + 1print(i)
print("1~1000的完全数共有{}个".format(count))

结果

在这里插入图片描述

思路5

a = []                                     # 创建空列表用于储存因子for i in range(2, 1000):              # 取除数for j in range(1, i):                  # 取小于除数的数作为被除数if i % j == 0:                # 如果两数相除,取余为0,也就是能整除,说明是因子a.append(j)                    # 将因子储存在列表里if sum(a) == i:                   # 当除数为i的情况完成后,将列表中的数求和,看是否满足因子相加等于除数的条件print(f"{i}是完数,因子包括{a}")    # 若符合,则输出完数和因子a.clear()                         # 将列表元素清除,进行下一个(i+1)的情况

结果

在这里插入图片描述

思路6

这个方法也是可以的,但是他不能在idle上运行。比赛的时候不能用pycharm。
在这里插入图片描述

结果

在这里插入图片描述

思路7

判断这个数是否是完数。但是并不能找出n以内的完数,也不能写出他们的因子。

n = int(input('::'))
c1 = 0
i = 1 
while i<=n-1: # 注意:要小于nif n%i == 0:c1+=ii+=1
if c1==n:print('这个数是完数')
else:print('这个数不是完数')

结果

在这里插入图片描述

思路8

def n(n):count = 0for i in range(1,n):if n%i==0:count +=iif count==n:return Trueelse:return Falsefor i in range(1,1001):# 1-1000判断if n(i):print(i)

结果

在这里插入图片描述

思路9

factor=[] 
for i in range(1,1000):for j in range(1,i):if i % j ==0:factor.append(j)if sum(factor)==i:print(i,"是完数")factor=[]

结果

在这里插入图片描述

总结

感觉这些方法都是大同小异,选择一个比较合适的就可以了。
列举这几种方法是方便大家学习。有不同的方法可以在评论留言。

这篇关于蓝桥杯python组--基础训练---2、#一个数如果恰好等于它的因子之和,这个数就称为“完数”,;例如:6=1+2+3,找出1000以内的的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python用Flask封装API及调用详解

《Python用Flask封装API及调用详解》本文介绍Flask的优势(轻量、灵活、易扩展),对比GET/POST表单/JSON请求方式,涵盖错误处理、开发建议及生产环境部署注意事项... 目录一、Flask的优势一、基础设置二、GET请求方式服务端代码客户端调用三、POST表单方式服务端代码客户端调用四

基于Python实现数字限制在指定范围内的五种方式

《基于Python实现数字限制在指定范围内的五种方式》在编程中,数字范围限制是常见需求,无论是游戏开发中的角色属性值、金融计算中的利率调整,还是传感器数据处理中的异常值过滤,都需要将数字控制在合理范围... 目录引言一、基础条件判断法二、数学运算巧解法三、装饰器模式法四、自定义类封装法五、NumPy数组处理

Python中经纬度距离计算的实现方式

《Python中经纬度距离计算的实现方式》文章介绍Python中计算经纬度距离的方法及中国加密坐标系转换工具,主要方法包括geopy(Vincenty/Karney)、Haversine、pyproj... 目录一、基本方法1. 使用geopy库(推荐)2. 手动实现 Haversine 公式3. 使用py

Python WSGI HTTP服务器Gunicorn使用详解

《PythonWSGIHTTP服务器Gunicorn使用详解》Gunicorn是Python的WSGI服务器,用于部署Flask/Django应用,性能高且稳定,支持多Worker类型与配置,可处... 目录一、什么是 Gunicorn?二、为什么需要Gunicorn?三、安装Gunicorn四、基本使用启

python urllib模块使用操作方法

《pythonurllib模块使用操作方法》Python提供了多个库用于处理URL,常用的有urllib、requests和urlparse(Python3中为urllib.parse),下面是这些... 目录URL 处理库urllib 模块requests 库urlparse 和 urljoin编码和解码

使用Python提取PDF大纲(书签)的完整指南

《使用Python提取PDF大纲(书签)的完整指南》PDF大纲(Outline)​​是PDF文档中的导航结构,通常显示在阅读器的侧边栏中,方便用户快速跳转到文档的不同部分,大纲通常以层级结构组织,包含... 目录一、PDF大纲简介二、准备工作所需工具常见安装问题三、代码实现完整代码核心功能解析四、使用效果控

Python自定义异常的全面指南(入门到实践)

《Python自定义异常的全面指南(入门到实践)》想象你正在开发一个银行系统,用户转账时余额不足,如果直接抛出ValueError,调用方很难区分是金额格式错误还是余额不足,这正是Python自定义异... 目录引言:为什么需要自定义异常一、异常基础:先搞懂python的异常体系1.1 异常是什么?1.2

更改linux系统的默认Python版本方式

《更改linux系统的默认Python版本方式》通过删除原Python软链接并创建指向python3.6的新链接,可切换系统默认Python版本,需注意版本冲突、环境混乱及维护问题,建议使用pyenv... 目录更改系统的默认python版本软链接软链接的特点创建软链接的命令使用场景注意事项总结更改系统的默

Linux升级或者切换python版本实现方式

《Linux升级或者切换python版本实现方式》本文介绍在Ubuntu/Debian系统升级Python至3.11或更高版本的方法,通过查看版本列表并选择新版本进行全局修改,需注意自动与手动模式的选... 目录升级系统python版本 (适用于全局修改)对于Ubuntu/Debian系统安装后,验证Pyt

Python实现开根号的五种方式

《Python实现开根号的五种方式》在日常数据处理、数学计算甚至算法题中,开根号是一个高频操作,但你知道吗?Python中实现开根号的方式远不止一种!本文总结了5种常用方法,感兴趣的小伙伴跟着小编一起... 目录一、为什么需要多种开根号方式?二、5种开根号方式详解方法1:数学库 math.sqrt() ——