UVA 1415 - Gauss Prime(数论,高斯素数拓展)

Posted wzjhoutai

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了UVA 1415 - Gauss Prime(数论,高斯素数拓展)相关的知识,希望对你有一定的参考价值。

UVA 1415 - Gauss Prime

题目链接

题意:给定a + bi,推断是否是高斯素数,i = sqrt(-2)。

思路:普通的高斯素数i = sqrt(-1),推断方法为:
1、假设a或b为0。推断还有一个数为4 * n + 3形式的素数(用到费马平方和定理)
2、假设a、b都不为0,推断a ^ 2 + b ^ 2 是否为素数

那么这题,提取出sqrt(2)来,就和基本情况一样了。
对于2,变成: 假设a、b都不为0,推断a ^ 2 + 2 b ^ 2是否为素数
对于1。事实上仅仅要a = 0,b始终能够拆成两个数相乘了,就不是高斯素数了

。这样一来问题就攻克了

代码:

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

const int N = 20005;
int t, a, b, prime[N], pn = 0, vis[N];

bool judge() {
    if (a == 0)
	return false;
    int tmp = a * a + 2 * b * b;
    for (int i = 0; i < pn && prime[i] < tmp; i++)
	if (tmp % prime[i] == 0) return false;
    return true;
}

int main() {
    vis[1] = 1;
    for (int i = 2; i < N; i++) {
	if (vis[i]) continue;
	prime[pn++] = i;
	for (int j = i * i; j < N; j += i) {
	    vis[j] = 1;
	}
    }
    scanf("%d", &t);
    while (t--) {
	scanf("%d%d", &a, &b);
	printf("%s\n", judge()?"Yes":"No");
    }
    return 0;
}


以上是关于UVA 1415 - Gauss Prime(数论,高斯素数拓展)的主要内容,如果未能解决你的问题,请参考以下文章

NYOJ 1066 CO-PRIME(数论)

数论HDU4135:Co-prime

[数论][容斥原理]Co-prime

POJ2689 Prime Distance(数论:素数筛选)

[暑假集训--数论]poj1365 Prime Land

[暑假集训--数论]poj2034 Anti-prime Sequences