问题描述
给定一个正整数n,求它的所有因子的和。例如,n=12时,它的因子有1,2,3,4,6,12,它们的和为28。编写一个C语言函数,输入n,输出它的因子和。
解决方案
解决这个问题的思路是,从1到n的平方根,遍历所有可能的因子,如果n能被它整除,就把它和它的商都加到因子和中。注意,如果n是一个完全平方数,那么它的平方根只能算一次。最后,返回因子和的值。
代码
下面是用C语言实现的代码:
#include <stdio.h>
#include <math.h>
// 定义一个函数,输入n,输出它的因子和
int factor_sum(int n) {
// 初始化因子和为0
int sum = 0;
// 从1到n的平方根,遍历所有可能的因子
for (int i = 1; i <= sqrt(n); i++) {
// 如果n能被i整除,说明i是一个因子
if (n % i == 0) {
// 把i和n/i都加到因子和中
sum += i + n / i;
// 如果n是一个完全平方数,那么它的平方根只能算一次,所以要减去多加的一次
if (i == sqrt(n)) {
sum -= i;
}
}
}
// 返回因子和的值
return sum;
}
// 主函数,用于测试
int main() {
// 定义一个正整数n
int n;
// 提示用户输入n的值
printf("请输入一个正整数n:\n");
// 从标准输入读取n的值
scanf("%d", &n);
// 调用函数,计算n的因子和
int result = factor_sum(n);
// 输出结果
printf("n的因子和为:%d\n", result);
// 返回0,表示程序正常结束
return 0;
}
运行结果:
总结
我使用了一个循环,从1到n的平方根,检查每一个可能的因子,如果n能被它整除,就把它和它的商都加到因子和中。还要注意一个特殊情况,就是当n是一个完全平方数时,它的平方根只能算一次。这个算法的时间复杂度是O(根号n),空间复杂度是O(1)。