#include<stdio.h>
#include<math.h>
int perfectNumber(int n){ //判断是否为完数
int sum = 0;
for(int i = 1; i <= n/2; i++){
if(n % i == 0){
sum += i;
}
}
if(sum == n)return 1;
return 0;
}
int main(){
int count = 0;
int m,n;
scanf("%d%d", &m, &n);
if(n > 1 && m > 1){ //1必定不是完数
if(m > n){ //确保m为左边界,n为右边界
int t = m;
m = n;
n = t;
}
for(int i = m; i <= n; i++){
if(perfectNumber(i)){
count++;
printf("%d\n", i);
}
}
}
printf("有 %d 个完数", count);
return 0;
}
输入:2 10000
输出:
6
28
496
8128
有 4 个完数