|
||||||||||||
|
洛谷题目传送门:https://www.luogu.org/problem/show?pid=UVA11105
思路:主题思路应该是筛法吧,先筛特殊的H-素数,再通过素数找到H-合成数。我才不会告诉你我调了三个小时。
提示:这是我们校内OJ,到洛谷上注意读题目输出要求。
直接上代码
1 #include<bits/stdc++.h> 2 #define MAXN 1000002 3 using namespace std; 4 int h; 5 bool prime[MAXN],s[MAXN]; 6 void init(int n)//筛H-素数的函数 7 { 8 for(int i=5;i<n/5;i+=4) 9 { 10 if(prime[i]==false) 11 { 12 for(int j=5;j*i<n;j+=4) 13 { 14 prime[i*j]=true; 15 } 16 } 17 } 18 } 19 20 int main() 21 { 22 init(MAXN); 23 for(int i=5;i*i<MAXN;i+=4) //直接处理最大范围内的H-合成数 24 { 25 if(prime[i]==false) 26 { 27 for(int j=5;i*j<MAXN;j+=4) 28 { 29 if(prime[j]==false) s[i*j]=true;//通过H-素数推出H-合成数 30 } 31 } 32 } 33 while(1) 34 { 35 int ans=0; 36 scanf("%d",&h); 37 if(h==0) break; 38 for(int i=5;i<=h;i+=4) 39 { 40 if(s[i]==true) ans++;//直接走一遍就OK了 41 } 42 printf("%d ",ans); 43 } 44 return 0; 45 }