java 一个数如果恰好等于它的因子之和,这个数称为完数,编写程序求出1000之内所有的完数。
时间: 2024-09-27 14:15:31 浏览: 41
1000以内的完数(该数等于其因子之和).exe
在 Java 中,我们可以创建一个程序来寻找1000以内所有的完数。完数也被称为完美数,是指一个正整数的所有真因数(除了本身之外的因子)相加的结果正好等于该数本身。以下是实现这一功能的一种简单方法:
```java
public class Main {
public static void main(String[] args) {
int limit = 1000;
for (int i = 1; i <= limit; i++) {
if (isPerfectNumber(i)) {
System.out.println("数字 " + i + " 是一个完数");
}
}
}
// 定义一个函数检查是否为完数
public static boolean isPerfectNumber(int number) {
int sum = 1;
for (int factor = 2; factor * factor <= number; factor++) {
if (number % factor == 0) { // 如果factor是因数
sum += factor; // 添加因子到总和
if (factor != number / factor) { // 如果因子不是它本身的平方,则添加另一个因子
sum += number / factor;
}
}
}
return sum == number && number > 1; // 检查sum是否等于number且number大于1(排除1)
}
}
```
在这个程序中,我们遍历从1到1000的所有数字,对每个数字调用 `isPerfectNumber` 函数进行判断。如果是完数,就打印出来。
阅读全文