zoukankan      html  css  js  c++  java
  • HDOJ 2098 分拆素数和 (数论)

    //http://acm.hdu.edu.cn/showproblem.php?pid=2098
    //标准的筛选法 
    #include<iostream>
    
    using namespace std;
    
    bool prime[10000+5];    //题目中给出了数值不会超过10000,这样刚好能够用筛选法 
    
    void Init()        //直接初始化素数表就好了。 
    {
        for(int i = 2; i <= 10000; ++i)        //初始条件为都是素数 
        {
            prime[i] = true;
        }
        for(int i =2;i <= 10000; ++i)        //然后用是素数的去划除非素数。 
        {
            if(prime[i] == true)
            {
                for(int j = 2; i*j <= 10000; ++j)
                    prime[i*j] = false;
            }
        }
    }
    
    int main()
    {
        int num, count, i;
        Init();
        while(scanf("%d",&num)!=EOF && num!=0)
        {
            count = 0;
            for(i=2; i<=num/2; ++i)    //对于每一个偶数 
            {
                //如果i和num-i都是素数(i!=num-i),且他们的和为num ,就符合条件了 
                if(prime[i] == true && prime[num-i] == true && i!=num-i)     
                    count++;
                //*****************************************************************/ 
            }
            printf("%d
    ",count);
        }
        return 0;
    }
  • 相关阅读:
    noi.openjudge——2971 抓住那头牛
    P1265 公路修建 洛谷
    P2330 [SCOI2005] 繁忙的都市 洛谷
    P1331 海战 洛谷
    P1464 Function 洛谷
    基于Manhattan最小生成树的莫队算法
    zoj3659
    poj1182
    hdu1325
    hdu3635
  • 原文地址:https://www.cnblogs.com/Lee-geeker/p/3375107.html
Copyright © 2011-2022 走看看