当前位置:网站首页>507. 完美数
507. 完美数
2022-08-03 10:22:00 【有时候。】
1. 题目描述
https://leetcode.cn/problems/perfect-number/
对于一个 正整数,如果它和除了它自身以外的所有 正因子 之和相等,我们称它为 「完美数」。
给定一个 整数 n, 如果是完美数,返回 true;否则返回 false。
示例:
输入:num = 28
输出:true
解释:28 = 1 + 2 + 4 + 7 + 14
1, 2, 4, 7, 和 14 是 28 的所有正因子。
2. 解题思路
通过枚举法找到整数n的所有正因子,首先想到从1枚举到n/2,提交后发现超时了,说明枚举的还是太多。因为整数的正因子除了1和自身外都是成对出现,比如28的正因子中有(2,14)和(4,7),加上之前做过类似的使用枚举法来解的题,所以很自然能想到枚举到 n \sqrt n n,只需要找到每对因子中小的一个,相当于找到了一对。
- python3
class Solution:
def checkPerfectNumber(self, num: int) -> bool:
if num == 1:
return False
sum = 1
d = 2
while d * d <= num:
if num % d == 0:
sum += d # 一对正因子中小的那个, 一对因子相同时只加上一个
if d * d < num:
sum += num / d # 一对正因子中大的那个
d += 1
return num == sum
- C++
class Solution {
public:
bool checkPerfectNumber(int num) {
int sum = 1;
int d = 2;
if (num == 1) return false;
while (d * d <= num){
if (num % d == 0){
sum += d;
if (d*d < num) sum += num / d;
}
d += 1;
}
return sum == num;
}
};
边栏推荐
猜你喜欢
随机推荐
gbase在轨道交通一般都采用哪种高可用架构?
DOM对象能干什么?
Mysql 主从复制 作用和原理
VL53L0X V2激光测距传感器 采集距离数据串口输出
优炫数据库在linux平台下服务启动失败的原因
被审稿人吐槽没有novelty!深度学习方向怎么找创新点?
使用GBase 8c数据库的时候,遇到这种报错“[[email protected] ~]$ /home/gbase/script/gha_ctl install -p……
MySQL 如何修改SQL语句,去掉语句中的or
开源一夏 | 教你快速实现“基于Docker快速构建基于Prometheus的MySQL监控系统”
阿里本地生活全域日志平台 Xlog 的思考与实践
pytorch installation error
MYSQL 修改时区的几种方法
MySQL 中 is null 和 =null 的区别
媒体查询代码
Pixel mobile phone system
按位取反怎么运算_按位取反运算
Go的Gin框架学习
js函数防抖和函数节流及其使用场景。
DOM0、DOM2、DOM3 事件
Regulation action for one hundred days during the summer, more than 700 traffic safety hidden dangers were thrown out