素数筛 uva 543

Posted HelloWorld!--By-MJY

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了素数筛 uva 543相关的知识,希望对你有一定的参考价值。

给你一个n求出n由2个奇质因子的和  这2个因子差最大

没有就输出‘Goldbach‘s conjecture is wrong.

#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<vector>
#include<math.h>

using namespace std;
#define MAXN 1000010
bool pri[MAXN];

int main()
{
    memset(pri,0,sizeof(pri));

    for(int i=2;i<=1000;i++)
    {
        if(!pri[i])
            for(int j=i*i;j<=MAXN;j=j+i)
                pri[j]=1;
    }
    int n;

    while(scanf("%d",&n)!=EOF&&n)
    {
        int a=n/2,i;
        for(i=3;i<=a;i++)
            if(!pri[i]&&!pri[n-i])
            {
                printf("%d = %d + %d\n",n,i,n-i);
                break;
            }
        if(i>a)
            printf("‘Goldbach‘s conjecture is wrong.\n");
    }

    return 0;
}

 

以上是关于素数筛 uva 543的主要内容,如果未能解决你的问题,请参考以下文章

UVa 10820 - Send a Table

UVA-11761-马尔可夫/记忆化搜索

UVA1213Sum of Different Primes(素数打表 + DP)

筛素数算法——线性筛素数算法

UVA 294 294 - Divisors (数论)

改进的筛素数法