shell:求某个数以内的所有完全数

来源:互联网 发布:js ajax push 编辑:程序博客网 时间:2024/06/07 05:04
#!/bin/bashfor ((i=1;$[(2**i-1)*(2**(i-1))]<=$1;i++))do        num=$(factor $i $[2**i-1]|awk 'NF==2'|wc -l)        if [ "$num" -eq 2 ]        then                 echo $[(2**i-1)*(2**(i-1))]        fidone


[root@centos6-1 ~]# sh getws.sh 100006284968128[root@centos6-1 ~]# 

这里用到了一个求完全数的公式:

设p为一个整数:
如果p是质数,且2^p-1也是质数,那么(2^p-1)*2^(p-1)便是一个完全数。
例如p=2,是一个质数,2^p-1=3也是质数,(2^p-1)*2^(p-1)=3*2=6,是完全数。
例如p=3,是一个质数,2^p-1=7也是质数,(2^p-1)*2^(p-1)=7*4=28,是完全数。
例如p=5,是一个质数,2^p-1=31也是质数,(2^p-1)*2^(p-1)=31*16=496是完全数。

参考链接: http://bbs.chinaunix.net/thread-4111789-1-1.html