#!/bin/bash
for ((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))]
fi
done
[root@centos6-1 ~]# sh getws.sh 10000
6
28
496
8128
[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是完全数。