24小时热门版块排行榜    

Znn3bq.jpeg
北京石油化工学院2026年研究生招生接收调剂公告
查看: 818  |  回复: 0

灵水墨

新虫 (正式写手)

[交流] 多项式g,f,在模p意义下的最大公因数, 程序计算

const { trace } = require("console";

function gcdModP(g, f, p) {
  let d = g.slice(); // 复制 g(x) 的系数到 d(x) 数组中
  let r = f.slice(); // 复制 f(x) 的系数到 r(x) 数组中
  while (!isZeroPoly(r)) {
    let t = trim(d);

    if (t.length < r.length) {
      [t, r] = [r, t]
    }
    // 复制 d(x) 的系数到 t(x) 数组中
    for (let i = 0; i < r.length; i++) {
      let j1 = t.length - r.length + i;
      t[j1] = t[j1] || 0n
      let quotient = (t[j1] * modInverse(r, p)) % p; // 计算商
      for (let j = 0; j < r.length; j++) {
        let index = t.length - r.length + i + j;
        // console.log(index)
        t[index] = t[index] || 0n
        t[index] -= quotient * r[j]; // 更新 t(x) 的系数
        t[index] = (t[index] % p + p) % p; // 取模
      }
      // console.log(t);
    }
    d = r.slice(); // 复制 r(x) 的系数到 d(x) 数组中
    r = t.slice(d.length - r.length + 1); // 复制 t(x) 的系数到 r(x) 数组中
    // console.log(d, r);
    r = trim(r);
  }
  // 将 d(x) 的系数除以它的首项系数,确保它是首项系数为 1 的幂次多项式
  let dLeadingCoefficient = d[d.length - 1];
  for (let i = 0; i < d.length; i++) {
    d = (d * modInverse(dLeadingCoefficient, p)) % p;
  }
  return d;
}

function modInverse(a, p) {
  // 使用扩展欧几里得算法计算 a 在模 p 意义下的逆元
  let [x, y] = extendedEuclideanAlgorithm(a, p);
  return (x % p + p) % p;
}

function extendedEuclideanAlgorithm(a, b) {
  // 扩展欧几里得算法返回 a 和 b 的最大公因数 d,以及满足 ax + by = d 的整数 x 和 y
  if (b === 0n) {
    return [1n, 0n, a];
  }
  let [x, y, d] = extendedEuclideanAlgorithm(b, a % b);
  return [y, x - (a / b) * y, d];
}



/**
* @param {Array<Number>} array
*/
function trim(array) {
  let i = 0;
  for (; i < array.length; i++) {
    // const element = array[index];
    if (array != 0n) {
      break
    }
  }
  let j = array.length - 1;
  for (; j > 0; j--) {
    // const element = array[index];
    if (array[j] != 0n) {
      break
    }
  }
  return array.slice(i, j + 1)
}
// console.log(trim([0n, 0n, 0n, 0n, 0n, 0n]));

/**
* 判断一个多项式是否为 0。
*
* @param {Array} poly - 待判断的多项式
* @returns {boolean} 是否为 0
*/
function isZeroPoly(poly) {
  for (let i = 0; i < poly.length; i++) {
    if (poly !== 0n) {
      return false;
    }
  }
  return true;
}

test()
function test() {
  // console.log(modInverse(5n, 47n));
  // console.log(trimStart([0n, 0n, 1n, 2n]))

  // 测试用例 1

  let g1 = [6n, 2n];
  let f1 = [17n, 15n];
  let p1 = 7n;
  console.log("结果", gcdModP(g1, f1, p1));


  // // 测试用例 3
  let f3 = [3n, 1n, 3n, 1n];
  let g3 = [3n, 1n]; // 3 + x
  let p3 = 101n;
  console.log("结果3", gcdModP(g3, f3, p3));

  let f4 = [3n, 4n, 4n, 1n];
  let g4 = [3n, 1n]; // 3 + x
  let p4 = 101n;
  console.log("结果4", gcdModP(g4, f4, p4));
}

module.exports = { gcdModP }



多项式g,f,在模p意义下的最大公因数,
结果4为什么是1呀,有人帮忙解答下吗

发自小木虫Android客户端
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 灵水墨 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿211电子信息347求调剂 +3 554916 2026-04-03 3/150 2026-04-07 23:22 by 如若时光倒流
[考研] 一志愿211,化学学硕,310分,本科重点双非,求调剂 +9 努力奋斗112 2026-04-07 9/450 2026-04-07 23:21 by JourneyLucky
[考研] 本科郑州大学,一志愿华东师范大学282求调剂 +20 熊哥xtk 2026-04-07 23/1150 2026-04-07 22:51 by JourneyLucky
[考研] 283分求调剂 +13 试试看呗 2026-04-04 13/650 2026-04-07 17:11 by 一只xx浩
[考研] 复试调剂 +9 春日来信- 2026-04-03 9/450 2026-04-07 15:17 by 尽舜尧1
[考研] 求调剂 +12 熊二想上岸 2026-04-04 12/600 2026-04-07 12:07 by Sammy2
[考研] 308求调剂 +3 终不似从前 2026-04-05 3/150 2026-04-05 22:23 by hemengdong
[考研] 找调剂 +10 楚乔乔 2026-04-01 10/500 2026-04-05 22:19 by syh9288
[考研] 081200-11408-276学硕求调剂 +4 崔wj 2026-04-04 5/250 2026-04-05 14:06 by imissbao
[考研] 298求调剂 +7 manman511 2026-04-05 7/350 2026-04-05 10:29 by 唐沐儿
[考研] 专硕310求调剂 +5 捞捞我…. 2026-04-04 6/300 2026-04-04 23:33 by barlinike
[考研] 290求调剂 +7 luoziheng 2026-04-04 7/350 2026-04-04 23:17 by lqwchd
[考研] 求生物学学硕调剂——364分 +7 云朵遛弯指南 2026-04-04 7/350 2026-04-04 22:49 by zhyzzh
[考研] 求调剂 +6 朔朔话 2026-04-02 7/350 2026-04-04 19:16 by 蓝云思雨
[考研] 291求调剂 +4 迷蒙木木 2026-04-01 5/250 2026-04-04 15:59 by sihailian3
[考研] 266求调剂 +8 学员97LZgn 2026-04-03 8/400 2026-04-04 09:02 by 20021109
[考研] 372分材料与化工(085600)一志愿湖南大学求调剂 +3 蓝笺片 2026-04-03 4/200 2026-04-03 17:58 by Jimmyandyou
[考研] 材料专硕322分 +11 哈哈哈吼吼吼哈 2026-04-01 11/550 2026-04-02 10:52 by lnilvy
[考研] 285求调剂 +11 AZMK 2026-04-01 11/550 2026-04-01 22:40 by peike
[考研] 310分求调剂 +4 成功上岸wang 2026-04-01 4/200 2026-04-01 20:35 by liu823948201
信息提示
请填处理意见