zoukankan      html  css  js  c++  java
  • 算法练习——完全数

      完全数
      定义:数的因子就是所有可以整除这个数的数,但是不包括这个数自身。比如15的因子是1, 3, 5 。
    如果一个正整数如果正好等于它的所有因子之和,这个数就称为“完数”。例如,6的因子为
    1, 2, 3, 而6=1+2+3,因此6是“完数”。
    维基百科
        完全数: https://zh.wikipedia.org/zh-cn/%E5%AE%8C%E5%85%A8%E6%95%B0
        梅森素数:https://zh.wikipedia.org/zh-cn/%E6%A2%85%E6%A3%AE%E7%B4%A0%E6%95%B0

        古希腊数学家欧几里得是通过2^{n-1} 	imes(2^n-1) 的表达式发现前四个完全数的。

    n=2:2^1 	imes(2^2-1)=6
    n=3:2^2 	imes(2^3-1)=28
    n=5:2^4 	imes(2^5-1)=496
    n=7:2^6 	imes(2^7-1)=8128

      一个偶数是完美数,当且仅当它具有如下形式:2^{n-1}(2^n-1),其中2^n-1是素数,此事实的充分性由欧几里得证明,而必要性则由欧拉所证明。

      梅森数是指形如2^n - 1的数,记为M_n;如果一个梅森数是素数那么它称为梅森素数

          当n合数时,M_n一定为合数。

          当n为素数时,M_n不一定皆为素数,比如M_2=2^2-1=3M_3=2^3-1=7是素数,但M_{11}=2^{11}-1=2047=23	imes 89却不是素数。

    算法:

    #include"stdafx.h"
    #include<stdio.h>
    #include<math.h>
    
    /**
      完全数
      数的因子就是所有可以整除这个数的数,但是不包括这个数自身。比如15的因子是1, 3, 5 。
    如果一个正整数如果正好等于它的所有因子之和,这个数就称为“完数”。例如,6的因子为
    1, 2, 3, 而6=1+2+3,因此6是“完数”。
    维基百科:
        完全数: https://zh.wikipedia.org/zh-cn/%E5%AE%8C%E5%85%A8%E6%95%B0
        梅森素数:https://zh.wikipedia.org/zh-cn/%E6%A2%85%E6%A3%AE%E7%B4%A0%E6%95%B0
    */
    int func(int n);
    void func2();
    int main()
    {
         printf("方案一:因式分解求和
    ");
         int n;
         for(int i = 2; i <1000; i=i+2){ //1000以下都是偶数
             if(func(i)){
                printf("%d	",i);
             }        
         }
         printf("
    方案二:使用数学公式
    ");
         func2();
         getchar();
         return 0;
    }
    
    // 方案一: 直接因子求和
    int func(int n){
        int d = 1,a;
        a = int(sqrt(1.0*n));  //对一个数,最多判断n开平方次
        for(int i = 2; i <= a; i++){
           if (n%i == 0)   //说明n能被b整除
            d += i + n/i;
        }  
        return  d==n;
    }
    //方案二: 数学公式 2^{n-1}*(2^n-1),n为素数
    void func2(){
        int n,p[4]={2,3,5,7};
        for(int i=0;i<4;i++){
            n= pow(2.0,p[i]-1)*(pow(2.0,p[i])-1);
            if(n<1000)
                printf("%d	",n);
            else        
                break;
        }
    }
  • 相关阅读:
    线程池的优雅关闭实践
    InheritableThreadLocal原理解析
    线程池踩坑
    两个线程通讯(生产-卖面包问题)
    谈谈redis的热key问题如何解决
    中国软件杯选题A1数据智能分析报告系统
    《程序员的思维修炼》读后感
    《算法导论》读后感
    《重构》读后感
    《代码整洁之道》读后感
  • 原文地址:https://www.cnblogs.com/zhuqingqin/p/5394636.html
Copyright © 2011-2022 走看看