如何解决leetcode中完美数的问题
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,小编给大家分享一下如何解决leetcode中完美数的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!题目链接https:
千家信息网最后更新 2025年12月03日如何解决leetcode中完美数的问题
小编给大家分享一下如何解决leetcode中完美数的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
题目链接
https://leetcode-cn.com/problems/perfect-number/
题目描述
对于一个 正整数,如果它和除了它自身以外的所有正因子之和相等,我们称它为"完美数"。
给定一个 正整数 n, 如果他是完美数,返回 True,否则返回 False
示例:
输入: 28
输出: True
解释: 28 = 1 + 2 + 4 + 7 + 14
注意:
输入的数字 n 不会超过 100,000,000. (1e8)
解题方案
思路
标签:数学
首先由于完美数的定义,需要排除自身,所以数字1一定不是完美数
其次我们需要计算num除了它自身以外的所有正因子之和sum,正因子必然是成对出现的,故而我们只需要遍历到num的平方根sqrt即可
以36为例,它的非自身外正因子有,1、2、3、4、6、9、12、18,其中1和6单独计算,[2, 18]、[3, 12]、[4, 9]都是对应关系、
所以只需要遍历到36的平方根6就可以获取全部正因子
1单独计算的原因是要排除自身,6单独计算的原因是 6 * 6 = 36,两个值相同,故而只能计算一遍
时间复杂度:O(logn),n为num的大小
Tips:完美数只有 6, 28, 496, 8128, 33550336 这几个,可以通过判断该数字是否为以下几个来解决
代码
Java版本
class Solution {
public boolean checkPerfectNumber(int num) {
if(num == 1) {
return false;
}
int sum = 1; // 正整数一定会有一个1,同时不用考虑自身,所以单独处理
int i = 2;
double sqrt = Math.sqrt(num);
for(;i < sqrt;i++) {
if(num % i == 0) {
sum += i;
sum += num / i;
}
}
// 此处单独处理的原因在于只需要加1次i值,如果在循环中会加2次
if(i * i == num) {
sum += i;
}
return sum == num;
}
}
JavaScript版本
/**
* @param {number} num
* @return {boolean}
*/
var checkPerfectNumber = function(num) {
if(num == 1) {
return false;
}
let sum = 1; // 正整数一定会有一个1,同时不用考虑自身,所以单独处理
let i = 2;
const sqrt = Math.sqrt(num);
for(;i < sqrt;i++) {
if(num % i == 0) {
sum += i;
sum += num / i;
}
}
// 此处单独处理的原因在于只需要加1次i值,如果在循环中会加2次
if(i * i == num) {
sum += i;
}
return sum == num;
};
画解


以上是"如何解决leetcode中完美数的问题"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
因子
原因
整数
处理
数字
篇文章
问题
不用
之和
内容
同时
平方根
版本
题目
循环
输入
复杂
相同
不怎么
两个
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
星空之上网络安全
安居宝面板服务器连接异常
四川机架式服务器
宝壶网络技术
美柚软件开发
自建数据库服务器
网络安全法由谁监督
小鹅网络技术诈骗
服务器电源开机
如何向数据库导入文件
计算机网络技术发源于
软件开发所属行业
数据库的分布式结构图
南阳计算机网络技术学校招生
网络技术岗位分析自身环境因素
白夜极光选错服务器了怎么办
厦门奕宝互联网科技有限公司
闪耀之光最新服务器是什么
关于自制软件开发的书
苹果说连接到服务器出现问题
互联网科技教育形式
奇安信在中国网络安全的排名
白嫖的服务器
外国人能玩lol服务器吗
软件开发的服务哪家好
怀柔区网络技术服务清单
网络安全与信息安全好的学校
点滴网络安全知识
mc经验起床服务器
杭州大数据软件开发定制费用