• zoj 2723 Semi-Prime


    // 题意都不好理解 我以为是求 一个数被分成2个素数和  然后是求分成2个素数积
    // 坑爹 忘记写 !=EOF 然后一直超时 然后换了几种 还是超时 一看别人代码 速度明显比我慢
    // 然后发现被自己坑了

    #include <iostream> #include <math.h> #include <map> #include <stack> #include <queue> #include <vector> #include <algorithm> #include <stdio.h> #include <string.h> using namespace std; #define maxm 10010 #define maxn 1000010 int gcd(int a,int b){ int r; while(r=a%b){a=b;b=r;} return b; } bool isp(int n){ if(n==2) return true; if(n%2==0||n==1) return false; int m=(int)(sqrt(n+1.0)); for(int i=3;i<=m;i+=2) if(n%i==0) return false; return true; } int fun(int n){ int m,i; if(n%2==0){ if(isp(n/2)) return 1; else return 0; }else{ int k; m=(int)(sqrt(n+1.0)); k=0; for(i=3;i<=m;i+=2) if(n%i==0){ if(isp(i)&&isp(n/i)) { return k=1; // printf("Yes "); break; } } if(!k) return 0; //printf("No "); } } int main() { int n; int m; int i,k; while(scanf("%d",&n)!=EOF){ if(fun(n)) printf("Yes "); else printf("No "); } return 0; }

    // 郁闷 求出所有素数 还是不如上述快

    #include <iostream> #include <math.h> #include <map> #include <stack> #include <queue> #include <vector> #include <algorithm> #include <stdio.h> #include <string.h> using namespace std; #define maxm 10010 #define maxn 1000010 int prim[maxn/3],p; bool f[maxn]; int gcd(int a,int b){ int r; while(r=a%b){a=b;b=r;} return b; } bool isp(int n){ if(n==2) return true; if(n%2==0||n==1) return false; int m=(int)(sqrt(n+1.0)); for(int i=3;i<=m;i+=2) if(n%i==0) return false; return true; } int getprime(){ int i,j; f[1]=true; for(i=4;i<=maxn;i+=2) f[i]=true; int m=(int)(sqrt(maxn+1.0)); for(i=3;i<=m;i+=2){ for(j=i*i;j<=maxn;j+=i) f[j]=true; } for(i=1;i<=maxn;i++) if(!f[i]) prim[p++]=i; } int main() { int n; int m; int i,k; getprime(); while(scanf("%d",&n)!=EOF){ m=(int)(sqrt(n+1.0)); k=i=0; while(prim[i]<=m){ if(n%prim[i]==0&&!f[n/prim[i]]) { k=1; break; } i++; } if(!k) printf("No "); else printf("Yes "); } return 0; }
    
    
    
    
    
  • 相关阅读:
    跳板机操作
    常用进制之间的转换
    vim加脚本注释和文本加密
    LAMP框架
    wiki团队协作软件Confluence
    NFS网络文件系统
    ORACLE-12C-RAC INSTALL
    通过DB_LINK按照分区表抽取数据
    Oracle Rac crs无法启动
    删除undotbs后,数据库无法启动
  • 原文地址:https://www.cnblogs.com/372465774y/p/3208798.html
Copyright © 2020-2023  润新知