This commit is contained in:
HuangHai
2025-09-21 15:29:15 +08:00
parent 6cd42b8ec2
commit c23a5f6f75

View File

@@ -1,26 +1,50 @@
#include <algorithm> #include <bits/stdc++.h>
#include <cstdio>
using namespace std; using namespace std;
const int N = 1e5 + 5; const int N = 1e5 + 5; // 数组最大长度,根据题目数据范围设定
int n, q, a[N], g; int n, q; // n整数个数q查询次数
int a[N]; // 存储输入的n个整数
int g; // 存储差分数组的最大公约数
/**
* 计算两个数的最大公约数
* @param a 第一个整数
* @param b 第二个整数
* @return a和b的最大公约数
* @note 特殊处理如果其中一个数为0返回两数之和即非零数本身
*/
int gcd(int a, int b) { int gcd(int a, int b) {
if (a == 0 || b == 0) if (a == 0 || b == 0)
return a + b; return a + b; // 处理0的情况gcd(0, x) = x
return gcd(b, a % b); return gcd(b, a % b); // 递归实现欧几里得算法
}
// 最大公约数,辗转相除法
int gcd(int a, int b) {
return b ? gcd(b, a % b) : a;
} }
int main() { int main() {
scanf("%d%d", &n, &q); // 读取整数个数n和查询次数q
cin >> n >> q;
// 读取n个整数到数组a中
for (int i = 1; i <= n; i++) for (int i = 1; i <= n; i++)
scanf("%d", &a[i]); cin >> a[i];
// 对数组进行排序,便于后续计算差分数组
sort(a + 1, a + n + 1); sort(a + 1, a + n + 1);
// 计算差分数组的最大公约数
// 数学原理gcd(a1+x, a2+x, ..., an+x) = gcd(gcd(a2-a1, a3-a1, ..., an-a1), a1+x)
for (int i = 2; i <= n; i++) for (int i = 2; i <= n; i++)
g = gcd(g, a[i] - a[i - 1]); g = gcd(g, a[i] - a[i - 1]); // 递推计算相邻元素差的最大公约数
// 处理q次查询
for (int i = 1; i <= q; i++) { for (int i = 1; i <= q; i++) {
int x; int x; // 查询的参数x
scanf("%d", &x); cin >> x;
// 计算并输出gcd(g, a[1]+x)即为所求的所有数加x后的最大公约数
printf("%d\n", gcd(g, a[1] + x)); printf("%d\n", gcd(g, a[1] + x));
} }
return 0; return 0;