16016
今天花了3个小时,做了一下给大一出的提高题,
没有算法,大多数学问题吧,
唉,发现自己太粗心了,很多题,遗漏,
初始化错误,结果磨蹭几十分钟。
这道题,我用的方法跟筛法求素数差不多,
先求出来N的所有约数(1和N本身除外)
然后通过筛法,把1~N 有公共约数的筛去。
然后就简单了,遍历一遍,看看有多少个新朋友。
代码:
// 找新朋友 #include <iostream> #include <cmath> #include <string.h> using namespace std; int ys[10001]; bool prim[33000]; int find_ys(int n) { int i,j,temp; j=0; // i从2到n/2 for(i=2;i<=n/2;++i) { if(n%i==0) ys[j++]=i; } return j; } int search(int len,int n) { memset(prim,0,sizeof(prim)); int i,j,sum; for(i=0;i<len;++i) { j=ys[i]; while(j<n) { prim[j]=1; j+=ys[i]; } } sum=0; for(i=1;i<n;++i) if(prim[i]==0) ++sum; return sum; } int main() { int cn,num,sl,len; int i,j; cin>>cn; while(cn--) { cin>>num; // 求约数,返回数组长度,数组存的就是约数 len=find_ys(num); // 看看有多少个新朋友 sl=search(len,num); cout<<sl<<endl; } return 0; }