iNOC产品部--完全数计算

【iNOC产品部–完全数计算】

完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数。 它所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于它本身。 例如:28,它有约数1、2、4、7、14、28,除去它本身28外,其余5个数相加,1+2+4+7+14=28。 给定函数count(int n),用于计算n以内(含n)完全数的个数。计算范围, 0 < n <= 500000 返回n以内完全数的个数。 异常情况返回-1

  • 完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数。
    它所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于它本身。
    例如:28,它有约数1、2、4、7、14、28,除去它本身28外,其余5个数相加,1+2+4+7+14=28。
    给定函数count(int n),用于计算n以内(含n)完全数的个数
    @param n 计算范围, 0 < n <= 500000
    @return n 以内完全数的个数, 异常情况返回-1

输入描述: 输入一个数字
输出描述: 输出完全数的个数

【解题思路】:
本题可以通过遍历每一个约数,求和,判断完全数。约数计算可以遍历sqrt(n)的范围。

#include<iostream>
#include<algorithm>
using namespace std;
int count(int n) {
	int cnt = 0;
	if ((n < 0) | (n>500000))
		return -1;
	else {
		for (int i = 2; i <= n; i++) {
			int sum = 0;
			//遍历范围
			int sq = sqrt(i);
			for (int j = 2; j <= sq; j++) {
				if (i%j == 0) {
					//如果j^2 = i,说明两个约数相同,只加一个 
					if (i / j == j) 
						sum += j; 
					else
						//否则,两个不同的约数都要相加 
						sum += j + (i / j);
				}
			}
			if (sum + 1 == i)
				cnt++;
		}
		return cnt;
	}
}
int main() {
	int input;
	while(cin >> input)
		cout << count(input) << endl;
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值