用java 写一个函数,求3000以内的亲密数对
时间: 2023-03-13 10:43:19 浏览: 88
我可以为你提供一个Java函数来求解3000以内的亲密数对:
public static void findAmicableNumbers(int n) {
for (int i = 1; i <= n; i++) {
int a = sumOfProperDivisors(i);
int b = sumOfProperDivisors(a);
if (i == b && a != b) {
System.out.println("(" + i + ", " + a + ")");
}
}
} public static int sumOfProperDivisors(int n) {
int sum = 0;
for (int i = 1; i < n; i++) {
if (n % i == 0) {
sum += i;
}
}
return sum;
}
相关问题
c语言用函数求3000以内的全部亲密数。
可以,以下是解决方案:
```c
#include <stdio.h>
// 计算因子和
int sum_of_factor(int n)
{
int sum = 0;
for (int i = 1; i < n; i++)
{
if (n % i == 0) sum += i;
}
return sum;
}
int main()
{
for (int i = 2; i <= 3000; i++)
{
int sum1 = sum_of_factor(i);
int sum2 = sum_of_factor(sum1);
if (sum2 == i && sum1 != i)
{
printf("%d和%d是一对亲密数\n", i, sum1);
}
}
return 0;
}
```
该程序可以计算3000以内的所有亲密数。
用c语言写用三个函数求1000以内完全数的和
好的,这是一个技术问题,我可以回答。以下是一个用 C 语言编写的求 1000 以内完全数的和的程序:
```
#include <stdio.h>
// 判断一个数是否为完全数
int isPerfectNum(int num) {
int i, sum = 0;
for (i = 1; i < num; i++) {
if (num % i == 0) {
sum += i;
}
}
if (sum == num) {
return 1;
} else {
return 0;
}
}
// 求 1000 以内所有的完全数
void getPerfectNums(int *perfectNums, int *count) {
int i;
for (i = 1; i <= 1000; i++) {
if (isPerfectNum(i)) {
perfectNums[*count] = i;
(*count)++;
}
}
}
// 求完全数的和
int getSum(int *nums, int count) {
int i, sum = 0;
for (i = 0; i < count; i++) {
sum += nums[i];
}
return sum;
}
int main() {
int perfectNums[50] = {0};
int count = 0;
getPerfectNums(perfectNums, &count);
int sum = getSum(perfectNums, count);
printf("1000以内完全数的和为:%d\n", sum);
return 0;
}
```