欧几里得算法
用于求两个数的最大公约数。复杂度在 以内。
#include <cstdio>
#include <iostream>
using namespace std;
int gcd(int a, int b)
{
if (b == 0) return a;
return gcd(b, a % b);
}
int main(void)
{
int a, b;
cin >> a >> b;
cout << gcd(a, b) << endl;
return 0;
}
求n个数的最大公约数
#include <cstdio>
#include <iostream>
using namespace std;
const int N = 1e5 + 5;
int arr[N];
int gcd(int a, int b)
{
if (b == 0) return a;
return gcd(b, a % b);
}
int main(void)
{
int n, a, b, ans;
cin >> n;
for (int i = 0; i < n; i++){
cin >> arr[i];
}
ans = arr[0];
for (int i = 0; i < n - 1; i++){
ans = gcd(ans, arr[i + 1]);
}
cout << ans << endl;
return 0;
}
扩展欧几里德算法
常用于求 的一组可行解。返回值为 ,并计算出了 和 。
#include <cstdio>
#include <iostream>
using namespace std;
int exgcd(int a, int b, int& x, int& y)
{
int d = a;
if (b != 0){
d = exgcd(b, a % b, y, x);
y -= (a / b) * x;
}
else{
x = 1;
y = 0;
}
return d;
}
int main(void)
{
int a, b, x, y;
cin >> a >> b;
cout << exgcd(a, b, x, y) << endl;
cout << x << " " << y << endl;
return 0;
}
对于int& x
说明这是传递给这个参数的实参的引用
对这个形参修改 就会对实参修改
是一种传址操作