这几个问题都可以用一个辅助数组来帮助求解,也有的称为是伴随数组。
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小的数,参考 这里