素数、亲和数、完数的求法

这几个问题都可以用一个辅助数组来帮助求解,也有的称为是伴随数组。

1、素数

筛选法求素数:把从1开始的、某一范围内的正整数从小到大顺序排列, 1不是素数,首先把它筛掉。剩下的数中选择最小的数是素数,然后去掉它的倍数。依次类推,直到筛子为空时结束。

void prime(int n)
{
	vector<bool> isPrime(n+1,true);
	int i;
	for (i = 2;i*i <= n;i++)
	{
		if(isPrime[i])
		{
			int j = i << 1;
			while (j <= n)
			{
				isPrime[j] = false;
				j += i;
			}
		}
	}
	for (i = 1;i <= n;i++)
	{
		if(isPrime[i])cout << i << " ";
	}
	cout << endl;
}

2、亲和数( 参考)

如果两个整数,其中每一个真因子的和都恰好等于另一个数,那么这两个数,就构成一对“亲和数,例如:220的真因子是:1、2、4、5、10、11、20、22、44、55、110;284的真因子是:1、2、4、71、142。而这两个数恰恰等于对方的真因子各自加起来的和即220=1+2+4+71+142=sum[284],
284=1+2+4+5+10+11+20+22+44+55+110=sum[220],即有sum[220]=sum[sum[284]]=284。

void friendNum(int n)
{
	vector<int> sum(n+1,1);
	int i;
	for (i = 2;i <= (n >> 1);i++)
	{
		int j = i << 1;//不包含本身
		while (j <= n)
		{
			sum[j] += i;
			j += i;
		}
	}
	for (i = 1;i <= n;i++)
	{
		if(sum[i] <= n && sum[sum[i]] == i && i < sum[i])cout << i << " " << sum[i] << endl;//防止越界、去重
	}
}

3、完数

如果一个数恰好等于它的因子之和,则称该数为“完全数。例如:第一个完全数是6,它有约数1、2、3、6,除去它本身6外,其余3个数相加,1+2+3=6。

void perfectNum(int n)
{
	vector<int> sum(n+1,1);
	int i;
	for (i = 2;i <= (n >> 1);i++)
	{
		int j = i << 1;//不包含自身
		while (j <= n)
		{
			sum[j] += i;
			j += i;
		}
	}
	for (i = 2;i <= n;i++)
	{
		if(sum[i] == i)cout << i << " ";
	}
	cout << endl;
}

另外还有一个伴随数组的应用,即求区间第k小的数,参考 这里




  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值