Project Euler——Problem 29 - Daybreakcx's Blog - Keep Programming! With Algorithm! With Fun!
Project Euler——Problem 29
daybreakcx
posted @ 2009年7月27日 18:58
in Prject Euler
, 1665 阅读
原题与答案:
Problem 29
25 October 2002
Consider all integer combinations of ab for 2 ≤ a
22=4, 23=8, 24=16, 25=32
32=9, 33=27, 34=81, 35=243
42=16, 43=64, 44=256, 45=1024
52=25, 53=125, 54=625, 55=3125
If they are then placed in numerical order, with any repeats removed, we get the following sequence of 15 distinct terms:
4, 8, 9, 16, 25, 27, 32, 64, 81, 125, 243, 256, 625, 1024, 3125
How many distinct terms are in the sequence generated by ab for 2 ≤ a
Answer:9183
分析与解答:
题目的意思是由在[2,100]区间中的a和b由形式构成的数有多少个。首先我们先确定一点,那就是这样的情况是存在的,比如,那么也就是说有重复的数值存在,其次是我们是否需要求出每一个数值的具体大小呢?答案是否定的,在[2,100]区间中,我们得到的最大数值是,大概有201位,直接去算那么数值比较大,而且比较也很久,我们就要想换一种方法。我们利用一个更快的方法来进行,假设a的质因素分解形式是,那么,我们可以将所有的数值都化成质因素分解的形式,这样我们只需要比较对应的次数,而且在100内的素数只有25个,比较的个数比较少。每次我们分解出a的形式,然后对于只要将次数都乘以b,就可以了,最后将这些次数序列排个序,计算有多少种即可,我的源程序代码如下所示:
-
#include<stdio.h>
-
#include<memory.h>
-
#include<algorithm>
-
bool nprime[101];
-
int a[26],i,j,k,n,ans,temp[25];
-
struct node
-
{
-
int list[25];
-
}res[9801];
-
bool cmp(node s,node t)
-
{
-
return memcmp(s.list,t.list,sizeof(res[0].list))<0;
-
}
-
void calc(int s)
-
{
-
int i;
-
for (i=1;i<=a[0];i++)
-
{
-
temp[i-1]=0;
-
while (s%a[i]==0)
-
{
-
s/=a[i];
-
temp[i-1]++;
-
}
-
}
-
}
-
int main()
-
{
-
a[0]=0;
-
memset(nprime,false,sizeof(nprime));
-
for (i=2;i<=100;i++)
-
if (!nprime[i])
-
{
-
a[++a[0]]=i;
-
if (i<=10)
-
for (j=i*i;j<=100;j+=i)
-
nprime[j]=true;
-
}
-
n=0;
-
for (i=2;i<=100;i++)
-
{
-
calc(i);
-
for (j=2;j<=100;j++)
-
{
-
for (k=0;k<a[0];k++)
-
res[n].list[k]=temp[k]*j;
-
n++;
-
}
-
}
-
std::sort(res,res+n,cmp);
-
ans=0;
-
for (i=j=0;;)
-
{
-
ans++;
-
while (j<n&&!memcmp(res[i].list,res[j].list,sizeof(res[0].list))) j++;
-
if (j==n) break;
-
i=j;
-
}
-
return 0;
-
}