文档章节

完美数 Perfect Number

叶枫啦啦
 叶枫啦啦
发布于 2017/06/27 15:34
字数 465
阅读 7
收藏 0

问题:

We define the Perfect Number is a positive integer that is equal to the sum of all its positive divisors except itself.

Now, given an integer n, write a function that returns true when it is a perfect number and false when it is not.

Example:

Input: 28
Output: True
Explanation: 28 = 1 + 2 + 4 + 7 + 14

Note: The input number n will not exceed 100,000,000. (1e8)

解决:

① 第一种思路是暴力解决,但是超时了。

public class Solution {
    public boolean checkPerfectNumber(int num) {
        if(num <= 0) return false;
        int sum = 0;
        for (int i = 1;i < num ;i ++ ) {
            if (num % i == 0) {
                sum += i;
            }
        }
        if (num == sum) {
            return true;
        }else{
            return false;
        }
    }
}

② 根据上一个解法,我们考虑2-sqrt(nums)范围内的数,之后的就是nums/之前的数。要注意的是要考虑到i!=num / i的情况。

public class Solution { //14ms
    public boolean checkPerfectNumber(int num) {
        if (num == 1) return false;
        int sum = 0;
        for (int i = 2; i <= Math.sqrt(num); i++) {
            if (num % i == 0) {
                sum += i;
                if (i != num / i) sum += num / i;
            }
        }
        sum ++;
        return sum == num;
    }
}

进阶版****:

public class Solution { //14ms
    public boolean checkPerfectNumber(int num) {
        if (num == 1) return false;
        int sum = 0;
        for (int i = 2; i <= Math.sqrt(num); i++) {
            if (num % i == 0) {
                sum += i + num / i;
            }
        }
        sum ++;
        return sum == num;
    }
}

每个完美数都可以写成从1开始的几个自然数之和,如:
6 = 1 + 2 + 3
28 = 1 + 2 + 3 + 4 + 5 + 6 + 7
我么可以看出,最后一个加数是最大的不能被2整除的因子n。由求和公式可以得到最终的和:                   sum = n *(n + 1)/ 2

public class Solution { //10ms
    public boolean checkPerfectNumber(int num) {       
        if(num <= 1) {
            return false;
        }        
        int sum = 0;
        int n = num;
        while(n % 2 == 0) { //可以被2整除
            n /= 2;
        }
        sum = n * (n + 1) / 2;
        return sum == num;
    }
}

④ sum = 1 + 2 + ...... + 最大的不能被2整除的因子。

public class Solution { //11ms
    public boolean checkPerfectNumber(int num) {
       if(num == 0 || num == 1) return false;
        int sum = 1;
        int n = 2;
        while(num % n == 0){
            sum += n;
            sum += num / n;
            n = 2 * n;          
        }

        return sum == num ? true : false;
    }
}

© 著作权归作者所有

共有 人打赏支持
叶枫啦啦
粉丝 10
博文 564
码字总数 335890
作品 0
海淀
树&二叉树&&满二叉树&&完全二叉树&&完满二叉树

目录 树 二叉树 树 名称 作用 根 树的顶端结点 孩子 当远离根(Root)的时候,直接连接到另外一个结点的结点被称之为孩子(Child); 双亲 相应地,另外一个结点称为孩子(child)的双亲(parent); 兄...

Chicago_01
08/27
0
0
perfect shuffle 算法的一个线性复杂度实现

今天又发现一个关于完美洗牌的算法。这个比较简单一些,由 microsoft的Peiyush Jain提出。 原论文: A Simple In-Place Algorithm for In-Shuffle. Peiyush Jain, Microsoft Corporation. J...

吟啸_徐行
2014/03/20
0
2
常用哈希(散列)函数集合 - NHF(Normal Hash Function)

从加密的角度讲,一个良好的的哈希函数f应当满足以下三个条件: 任意y,找x,使得f(x)=y,非常困难 给定x1,找x2,使得f(x1)=f(x2),非常困难 找x1,x2,使得f(x1)=f(x2),非常困难 从检索访...

开源中国驻成都办事处
2012/09/13
0
0
简约强大的自定义滚动条插件--Perfect Scrollbar

Perfect Scrollbar 简约,但完美的自定义滚动条插件。 完美意味着什么? 无需对默认元素有任何更改 滚动条不应影响默认设计布局 滚动条的设计应(几乎)完全可定制 若容器或内容大小发生变化...

匿名
2017/08/29
200
0
滚动条插件 Perfect Scrollbar 0.8.0 发布

Perfect Scrollbar 0.8.0 已发布,更新内容: 使用 npm 5 替代 Yarn 放弃对 IE 10 的支持 重构通用库 修复 TypeScript 定义 增加四舍五入的误差容差 完整更新内容 Perfect Scrollbar 是一个简...

王练
2017/08/30
722
4

没有更多内容

加载失败,请刷新页面

加载更多

laravel 微信支付

1.composer加载laravel微信支付第三方文件 composer require "overtrue/laravel-wechat:~4.0" composer require simplesoftwareio/simple-qrcode 1.3.* //composer生成二维码文件 2.改confi......

vio小黑
14分钟前
0
0
学习设计模式——抽象工厂模式

1. 认识抽象工厂模式 1. 定义:提供一个创建一系列相关或互相依赖的对象的接口,而无需指定它们具体的类。 2. 组成结构: AbstractFactory:抽象工厂类,定义创建一系列对象的操作接口 Fact...

江左煤郎
14分钟前
0
0
ES6的let块级作用域和变量不可提升导致一个比较容易出现的错误

今天在写NodeJS代码的时候出现一个变量一直提示未定义,简化后的代码如下: let param = 1;{ console.log(param);} 就在想,不至于啊。不是继承上层的声明吗? 继续看下去,发现原来...

MKjy
21分钟前
0
0
50:nginx访问日记|日记切割|静态文件不记录日记和过期时间

1、nginx访问日记: 日记格式:在主配置文件nginx.conf里搜索log_format; [root@localhost_001 conf]# vim nginx.conflog_format combined_realip '$remote_addr $http_x_forwarded_for ......

芬野de博客
24分钟前
0
0
前后端正常交互的流程

1、评审阶段:产品召集前后端进行需求评审,前后端各自捋清楚自己的业务量以及联调之间工作量,从而进行开发时间评估。 2、开发准备阶段:前后端一起商量需求中需要联调的部分,进行接口的口...

Jack088
25分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部