hdu 3792 树状数组

求小于n的孪生素数有几对。。。。

暴力貌似也可以过,我用了树状数组,预处理了一下,每次输入n直接求sum(n),表示小于n的孪生素数的对数

View Code
#include<stdio.h>
#include<string.h>
#define MAX 100000
int c[100000];
int lowbit(int x)
{
return x&(-x);
}
void add(int x,int num)
{
while(x<=MAX)
{
c[x]+=num;
x+=lowbit(x);
}
}
int sum(int x)
{
int ans=0;
while(x>0)
{
ans+=c[x];
x-=lowbit(x);
}
return ans;
}
int flag[100000],p[10000];
int main()
{
int i,j,k,tot=0;
memset(flag,0,sizeof(flag));
for(i=2;i<=100000;i++)
{
if(!flag[i])
{
p[++tot]=i;
for(j=2*i;j<=100000;j+=i)
{
flag[j]=1;
}
}
}
for(i=2;i<=tot;i++)
{
if(p[i]-p[i-1]==2)
{
add(p[i],1);
}
}
int n;
while(scanf("%d",&n),n>0)
{
if(n==0) printf("0\n");
else
printf("%d\n",sum(n));
}
return 0;
}



posted @ 2011-12-14 05:20  Because Of You  Views(277)  Comments(0Edit  收藏  举报