程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> UVA 10951 - Polynomial GCD(數論)

UVA 10951 - Polynomial GCD(數論)

編輯:C++入門知識

UVA 10951 - Polynomial GCD

題目鏈接

題意:給定兩個多項式,求多項式的gcd,要求首項次數為1,多項式中的運算都%n,並且n為素數.

思路:和gcd基本一樣,只不過傳入的是兩個多項式,由於有%n這個條件,所以計算過程可以用乘法逆去計算除法模,然後最後輸出的時候每項除掉首項的次數就是答案了.

代碼:

#include 
#include 
#include 
using namespace std;

int n;
vector f, g;

int exgcd(int a, int b, int &x, int &y) {
    if (!b) {x = 1; y = 0; return a;}
    int d = exgcd(b, a % b, y, x);
    y -= a / b * x;
    return d;
}

int inv(int a, int n) {
    int x, y;
    exgcd(a, n, x , y);
    return (x + n) % n;
}

vector pmod(vector f, vector g) {
    int fz = f.size(), gz = g.size();
    for (int i = 0; i < fz; i++) {
	int k = fz - i - gz;
	if (k < 0) break;
	int a = f[i] * inv(g[0], n) % n;
	for (int j = 0; j < gz; j++) {
	    int now = i + j;
	    f[now] = ((f[now] - a * g[j] % n) % n + n) % n;
	}
    }
    vector ans;
    int p = -1;
    for (int i = 0; i < fz; i++) if (f[i] != 0) {p = i; break;}
    if (p >= 0) for (int i = p; i < fz; i++) ans.push_back(f[i]);
    return ans;
}

vector gcd(vector f, vector g) {
    if (g.size() == 0) return f;
    return gcd(g, pmod(f, g));
}

int main() {
    int cas = 0;
    while (~scanf("%d", &n) && n) {
	f.clear(); g.clear();
	int a, k;
	scanf("%d", &a);
	for (int i = 0; i <= a; i++) {
	    scanf("%d", &k);
	    f.push_back(k);
	}
	scanf("%d", &a);
	for (int i = 0; i <= a; i++) {
	    scanf("%d", &k);
	    g.push_back(k);
	}
	vector ans = gcd(f, g);
	int tmp = inv(ans[0], n), ansz = ans.size();;
	printf("Case %d: %d", ++cas, ansz - 1);
	for (int i = 0; i < ansz; i++) {
	    printf(" %d", ans[i] * tmp % n);
	}
	printf("\n");
    }
    return 0;
}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved