亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? zz_px1.c

?? 密碼大家Shoup寫的數(shù)論算法c語言實現(xiàn)
?? C
?? 第 1 頁 / 共 3 頁
字號:
#include <NTL/ZZ_pX.h>#include <NTL/new.h>NTL_START_IMPLlong divide(ZZ_pX& q, const ZZ_pX& a, const ZZ_pX& b){   if (IsZero(b)) {      if (IsZero(a)) {         clear(q);         return 1;      }      else         return 0;   }   ZZ_pX lq, r;   DivRem(lq, r, a, b);   if (!IsZero(r)) return 0;    q = lq;   return 1;}long divide(const ZZ_pX& a, const ZZ_pX& b){   if (IsZero(b)) return IsZero(a);   ZZ_pX lq, r;   DivRem(lq, r, a, b);   if (!IsZero(r)) return 0;    return 1;}void ZZ_pXMatrix::operator=(const ZZ_pXMatrix& M){   elts[0][0] = M.elts[0][0];   elts[0][1] = M.elts[0][1];   elts[1][0] = M.elts[1][0];   elts[1][1] = M.elts[1][1];}void RightShift(ZZ_pX& x, const ZZ_pX& a, long n){   if (n < 0) {      if (n < -NTL_MAX_LONG) Error("overflow in RightShift");      LeftShift(x, a, -n);      return;   }   long da = deg(a);   long i;    if (da < n) {      clear(x);      return;   }   if (&x != &a)      x.rep.SetLength(da-n+1);   for (i = 0; i <= da-n; i++)      x.rep[i] = a.rep[i+n];   if (&x == &a)      x.rep.SetLength(da-n+1);   x.normalize();}void LeftShift(ZZ_pX& x, const ZZ_pX& a, long n){   if (n < 0) {      if (n < -NTL_MAX_LONG) Error("overflow in LeftShift");      RightShift(x, a, -n);      return;   }   if (n >= (1L << (NTL_BITS_PER_LONG-4)))      Error("overflow in LeftShift");   if (IsZero(a)) {      clear(x);      return;   }   long m = a.rep.length();   x.rep.SetLength(m+n);   long i;   for (i = m-1; i >= 0; i--)      x.rep[i+n] = a.rep[i];   for (i = 0; i < n; i++)      clear(x.rep[i]);}void ShiftAdd(ZZ_pX& U, const ZZ_pX& V, long n)// assumes input does not alias output{   if (IsZero(V))      return;   long du = deg(U);   long dv = deg(V);   long d = max(du, n+dv);   U.rep.SetLength(d+1);   long i;   for (i = du+1; i <= d; i++)      clear(U.rep[i]);   for (i = 0; i <= dv; i++)      add(U.rep[i+n], U.rep[i+n], V.rep[i]);   U.normalize();}void ShiftSub(ZZ_pX& U, const ZZ_pX& V, long n)// assumes input does not alias output{   if (IsZero(V))      return;   long du = deg(U);   long dv = deg(V);   long d = max(du, n+dv);   U.rep.SetLength(d+1);   long i;   for (i = du+1; i <= d; i++)      clear(U.rep[i]);   for (i = 0; i <= dv; i++)      sub(U.rep[i+n], U.rep[i+n], V.rep[i]);   U.normalize();}void mul(ZZ_pX& U, ZZ_pX& V, const ZZ_pXMatrix& M)// (U, V)^T = M*(U, V)^T{   long d = deg(U) - deg(M(1,1));   long k = NextPowerOfTwo(d - 1);   // When the GCD algorithm is run on polynomials of degree n, n-1,    // where n is a power of two, then d-1 is likely to be a power of two.   // It would be more natural to set k = NextPowerOfTwo(d+1), but this   // would be much less efficient in this case.   // We optimize this case, as it does sometimes arise naturally   // in some situations.   long n = (1L << k);   long xx;   ZZ_p a0, a1, b0, b1, c0, d0, u0, u1, v0, v1, nu0, nu1, nv0;   static ZZ t1, t2;   if (n == d-1)      xx = 1;   else if (n == d)      xx = 2;   else       xx = 3;   switch (xx) {   case 1:      GetCoeff(a0, M(0,0), 0);      GetCoeff(a1, M(0,0), 1);      GetCoeff(b0, M(0,1), 0);      GetCoeff(b1, M(0,1), 1);      GetCoeff(c0, M(1,0), 0);      GetCoeff(d0, M(1,1), 0);      GetCoeff(u0, U, 0);      GetCoeff(u1, U, 1);      GetCoeff(v0, V, 0);      GetCoeff(v1, V, 1);      mul(t1, rep(a0), rep(u0));      mul(t2, rep(b0), rep(v0));      add(t1, t1, t2);       conv(nu0, t1);      mul(t1, rep(a1), rep(u0));      mul(t2, rep(a0), rep(u1));      add(t1, t1, t2);      mul(t2, rep(b1), rep(v0));      add(t1, t1, t2);      mul(t2, rep(b0), rep(v1));      add(t1, t1, t2);      conv(nu1, t1);      mul(t1, rep(c0), rep(u0));      mul(t2, rep(d0), rep(v0));      add (t1, t1, t2);      conv(nv0, t1);         break;   case 2:      GetCoeff(a0, M(0,0), 0);      GetCoeff(b0, M(0,1), 0);      GetCoeff(u0, U, 0);      GetCoeff(v0, V, 0);      mul(t1, rep(a0), rep(u0));      mul(t2, rep(b0), rep(v0));      add(t1, t1, t2);       conv(nu0, t1);      break;   case 3:      break;   }   FFTRep RU(INIT_SIZE, k), RV(INIT_SIZE, k), R1(INIT_SIZE, k),           R2(INIT_SIZE, k);   ToFFTRep(RU, U, k);     ToFFTRep(RV, V, k);     ToFFTRep(R1, M(0,0), k);   mul(R1, R1, RU);   ToFFTRep(R2, M(0,1), k);   mul(R2, R2, RV);   add(R1, R1, R2);   FromFFTRep(U, R1, 0, d);   ToFFTRep(R1, M(1,0), k);   mul(R1, R1, RU);   ToFFTRep(R2, M(1,1), k);   mul(R2, R2, RV);   add(R1, R1, R2);   FromFFTRep(V, R1, 0, d-1);   // now fix-up results   switch (xx) {   case 1:      GetCoeff(u0, U, 0);      sub(u0, u0, nu0);      SetCoeff(U, d-1, u0);      SetCoeff(U, 0, nu0);      GetCoeff(u1, U, 1);      sub(u1, u1, nu1);      SetCoeff(U, d, u1);      SetCoeff(U, 1, nu1);      GetCoeff(v0, V, 0);      sub(v0, v0, nv0);      SetCoeff(V, d-1, v0);      SetCoeff(V, 0, nv0);      break;         case 2:      GetCoeff(u0, U, 0);      sub(u0, u0, nu0);      SetCoeff(U, d, u0);      SetCoeff(U, 0, nu0);      break;   }}void mul(ZZ_pXMatrix& A, ZZ_pXMatrix& B, ZZ_pXMatrix& C)// A = B*C, B and C are destroyed{   long db = deg(B(1,1));   long dc = deg(C(1,1));   long da = db + dc;   long k = NextPowerOfTwo(da+1);   FFTRep B00, B01, B10, B11, C0, C1, T1, T2;      ToFFTRep(B00, B(0,0), k); B(0,0).kill();   ToFFTRep(B01, B(0,1), k); B(0,1).kill();   ToFFTRep(B10, B(1,0), k); B(1,0).kill();   ToFFTRep(B11, B(1,1), k); B(1,1).kill();   ToFFTRep(C0, C(0,0), k);  C(0,0).kill();   ToFFTRep(C1, C(1,0), k);  C(1,0).kill();   mul(T1, B00, C0);   mul(T2, B01, C1);   add(T1, T1, T2);   FromFFTRep(A(0,0), T1, 0, da);   mul(T1, B10, C0);   mul(T2, B11, C1);   add(T1, T1, T2);   FromFFTRep(A(1,0), T1, 0, da);   ToFFTRep(C0, C(0,1), k);  C(0,1).kill();   ToFFTRep(C1, C(1,1), k);  C(1,1).kill();   mul(T1, B00, C0);   mul(T2, B01, C1);   add(T1, T1, T2);   FromFFTRep(A(0,1), T1, 0, da);   mul(T1, B10, C0);   mul(T2, B11, C1);   add(T1, T1, T2);   FromFFTRep(A(1,1), T1, 0, da);}void IterHalfGCD(ZZ_pXMatrix& M_out, ZZ_pX& U, ZZ_pX& V, long d_red){   M_out(0,0).SetMaxLength(d_red);   M_out(0,1).SetMaxLength(d_red);   M_out(1,0).SetMaxLength(d_red);   M_out(1,1).SetMaxLength(d_red);   set(M_out(0,0));   clear(M_out(0,1));   clear(M_out(1,0)); set(M_out(1,1));   long goal = deg(U) - d_red;   if (deg(V) <= goal)      return;   ZZVec tmp(deg(U)+1, ZZ_pInfo->ExtendedModulusSize);   ZZ_pX Q, t(INIT_SIZE, d_red);   while (deg(V) > goal) {      PlainDivRem(Q, U, U, V, tmp);      swap(U, V);      mul(t, Q, M_out(1,0));      sub(t, M_out(0,0), t);      M_out(0,0) = M_out(1,0);      M_out(1,0) = t;      mul(t, Q, M_out(1,1));      sub(t, M_out(0,1), t);      M_out(0,1) = M_out(1,1);      M_out(1,1) = t;   }}   void HalfGCD(ZZ_pXMatrix& M_out, const ZZ_pX& U, const ZZ_pX& V, long d_red){   if (IsZero(V) || deg(V) <= deg(U) - d_red) {      set(M_out(0,0));   clear(M_out(0,1));      clear(M_out(1,0)); set(M_out(1,1));       return;   }   long n = deg(U) - 2*d_red + 2;   if (n < 0) n = 0;   ZZ_pX U1, V1;   RightShift(U1, U, n);   RightShift(V1, V, n);   if (d_red <= NTL_ZZ_pX_HalfGCD_CROSSOVER) {      IterHalfGCD(M_out, U1, V1, d_red);      return;   }   long d1 = (d_red + 1)/2;   if (d1 < 1) d1 = 1;   if (d1 >= d_red) d1 = d_red - 1;   ZZ_pXMatrix M1;   HalfGCD(M1, U1, V1, d1);   mul(U1, V1, M1);   long d2 = deg(V1) - deg(U) + n + d_red;   if (IsZero(V1) || d2 <= 0) {      M_out = M1;      return;   }   ZZ_pX Q;   ZZ_pXMatrix M2;   DivRem(Q, U1, U1, V1);   swap(U1, V1);   HalfGCD(M2, U1, V1, d2);   ZZ_pX t(INIT_SIZE, deg(M1(1,1))+deg(Q)+1);   mul(t, Q, M1(1,0));   sub(t, M1(0,0), t);   swap(M1(0,0), M1(1,0));   swap(M1(1,0), t);   t.kill();   t.SetMaxLength(deg(M1(1,1))+deg(Q)+1);   mul(t, Q, M1(1,1));   sub(t, M1(0,1), t);   swap(M1(0,1), M1(1,1));   swap(M1(1,1), t);   t.kill();   mul(M_out, M2, M1); }void XHalfGCD(ZZ_pXMatrix& M_out, ZZ_pX& U, ZZ_pX& V, long d_red){   if (IsZero(V) || deg(V) <= deg(U) - d_red) {      set(M_out(0,0));   clear(M_out(0,1));      clear(M_out(1,0)); set(M_out(1,1));       return;   }   long du = deg(U);   if (d_red <= NTL_ZZ_pX_HalfGCD_CROSSOVER) {      IterHalfGCD(M_out, U, V, d_red);      return;   }   long d1 = (d_red + 1)/2;   if (d1 < 1) d1 = 1;   if (d1 >= d_red) d1 = d_red - 1;   ZZ_pXMatrix M1;   HalfGCD(M1, U, V, d1);   mul(U, V, M1);   long d2 = deg(V) - du + d_red;   if (IsZero(V) || d2 <= 0) {      M_out = M1;      return;   }   ZZ_pX Q;   ZZ_pXMatrix M2;   DivRem(Q, U, U, V);   swap(U, V);   XHalfGCD(M2, U, V, d2);   ZZ_pX t(INIT_SIZE, deg(M1(1,1))+deg(Q)+1);   mul(t, Q, M1(1,0));   sub(t, M1(0,0), t);   swap(M1(0,0), M1(1,0));   swap(M1(1,0), t);   t.kill();   t.SetMaxLength(deg(M1(1,1))+deg(Q)+1);   mul(t, Q, M1(1,1));   sub(t, M1(0,1), t);   swap(M1(0,1), M1(1,1));   swap(M1(1,1), t);   t.kill();   mul(M_out, M2, M1); }void HalfGCD(ZZ_pX& U, ZZ_pX& V){   long d_red = (deg(U)+1)/2;   if (IsZero(V) || deg(V) <= deg(U) - d_red) {      return;   }   long du = deg(U);   long d1 = (d_red + 1)/2;   if (d1 < 1) d1 = 1;   if (d1 >= d_red) d1 = d_red - 1;   ZZ_pXMatrix M1;   HalfGCD(M1, U, V, d1);   mul(U, V, M1);   long d2 = deg(V) - du + d_red;   if (IsZero(V) || d2 <= 0) {      return;   }   M1(0,0).kill();   M1(0,1).kill();   M1(1,0).kill();   M1(1,1).kill();   ZZ_pX Q;   DivRem(Q, U, U, V);   swap(U, V);   HalfGCD(M1, U, V, d2);   mul(U, V, M1); }void GCD(ZZ_pX& d, const ZZ_pX& u, const ZZ_pX& v){   ZZ_pX u1, v1;   u1 = u;   v1 = v;   if (deg(u1) == deg(v1)) {      if (IsZero(u1)) {         clear(d);         return;      }      rem(v1, v1, u1);   }   else if (deg(u1) < deg(v1)) {      swap(u1, v1);   }   // deg(u1) > deg(v1)   while (deg(u1) > NTL_ZZ_pX_GCD_CROSSOVER && !IsZero(v1)) {      HalfGCD(u1, v1);      if (!IsZero(v1)) {         rem(u1, u1, v1);         swap(u1, v1);      }   }   PlainGCD(d, u1, v1);}void XGCD(ZZ_pX& d, ZZ_pX& s, ZZ_pX& t, const ZZ_pX& a, const ZZ_pX& b){   ZZ_p w;   if (IsZero(a) && IsZero(b)) {      clear(d);      set(s);      clear(t);      return;   }   ZZ_pX U, V, Q;   U = a;   V = b;   long flag = 0;   if (deg(U) == deg(V)) {      DivRem(Q, U, U, V);      swap(U, V);      flag = 1;   }   else if (deg(U) < deg(V)) {      swap(U, V);      flag = 2;   }   ZZ_pXMatrix M;   XHalfGCD(M, U, V, deg(U)+1);   d = U;   if (flag == 0) {      s = M(0,0);       t = M(0,1);   }   else if (flag == 1) {      s = M(0,1);      mul(t, Q, M(0,1));      sub(t, M(0,0), t);   }   else {  /* flag == 2 */      s = M(0,1);      t = M(0,0);   }   // normalize   inv(w, LeadCoeff(d));   mul(d, d, w);   mul(s, s, w);   mul(t, t, w);}      void IterBuild(ZZ_p* a, long n){   long i, k;   ZZ_p b, t;   if (n <= 0) return;   negate(a[0], a[0]);   for (k = 1; k <= n-1; k++) {      negate(b, a[k]);      add(a[k], b, a[k-1]);      for (i = k-1; i >= 1; i--) {         mul(t, a[i], b);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久先锋影音av鲁色资源| 午夜不卡av免费| 精品蜜桃在线看| 欧美一区二区三区免费视频 | 欧美理论片在线| 欧美一区二区三区不卡| 国产精品1区2区| 麻豆精品一区二区三区| 日韩激情一区二区| 免费成人av资源网| 国产精品18久久久久久久久久久久| 久久精品72免费观看| 国产制服丝袜一区| 国产不卡免费视频| 91社区在线播放| 欧美私模裸体表演在线观看| 欧美精品九九99久久| 精品精品国产高清a毛片牛牛| 久久精品视频免费观看| 亚洲欧美综合在线精品| 亚洲第一成年网| 国产麻豆成人精品| 色屁屁一区二区| 日韩一区二区在线看片| 亚洲色图欧美在线| 不卡一区中文字幕| 亚洲6080在线| 九九精品一区二区| 成人性生交大片免费看视频在线 | 精品一区二区久久| 国产69精品久久久久777| 91女人视频在线观看| 欧美三区免费完整视频在线观看| 日韩欧美一区二区三区在线| 国产精品网曝门| 亚洲成a人片在线不卡一二三区 | 欧洲另类一二三四区| 911精品国产一区二区在线| 国产午夜精品理论片a级大结局| 亚洲欧洲www| 久久99精品国产麻豆不卡| 91视频国产观看| 日韩三级视频在线观看| 亚洲色图视频网站| 国产精品资源网站| 欧美日韩免费视频| 国产精品高潮久久久久无| 日本美女一区二区三区视频| 成人综合婷婷国产精品久久免费| 91精品国产欧美一区二区| 亚洲欧美偷拍卡通变态| 国产激情一区二区三区| 欧美日韩国产高清一区| 日韩伦理av电影| 国产91在线观看| 在线亚洲欧美专区二区| 成人高清在线视频| 天天操天天综合网| 91香蕉视频mp4| 欧美美女激情18p| 国产精品视频观看| 国产自产v一区二区三区c| 欧美日韩亚洲高清一区二区| 亚洲欧洲日产国码二区| 国产福利91精品一区二区三区| 欧美性生活大片视频| 亚洲在线免费播放| 在线观看日韩av先锋影音电影院| 国产精品欧美综合在线| 不卡av在线网| 亚洲欧美怡红院| 高清av一区二区| 国产精品三级av在线播放| 成人激情图片网| 亚洲国产精品成人综合| 国产午夜亚洲精品羞羞网站| 亚洲黄色小说网站| 欧美精品一区二区三区一线天视频| 亚洲第一狼人社区| 在线观看成人小视频| 一级中文字幕一区二区| 在线观看视频91| 日产精品久久久久久久性色| 91精品国产综合久久久久久久久久 | 久久99精品国产.久久久久| 在线不卡中文字幕播放| 日韩av一区二区在线影视| 欧美一区二区精品| 开心九九激情九九欧美日韩精美视频电影| 69久久夜色精品国产69蝌蚪网| 日本中文在线一区| 国产亚洲综合性久久久影院| 丰满放荡岳乱妇91ww| 亚洲欧美日韩国产综合在线| 欧美日韩色一区| 国产视频亚洲色图| 国产精品久久久久影院| www.久久精品| 一区二区三国产精华液| 欧美丰满少妇xxxxx高潮对白| 免费观看一级欧美片| 久久九九影视网| 色婷婷激情久久| 日本va欧美va瓶| 国产精品久久久久天堂| 欧美乱妇20p| 成人永久免费视频| 亚洲国产sm捆绑调教视频| 日韩你懂的在线播放| 成人久久视频在线观看| 日韩黄色小视频| 成人免费一区二区三区视频| 欧美一区二区三区爱爱| 北条麻妃一区二区三区| 久久国产精品色婷婷| 亚洲男女一区二区三区| 精品国产一区二区三区久久久蜜月| 欧美日韩一区二区三区四区| 欧美激情一区二区三区蜜桃视频| 久久久夜色精品亚洲| 99麻豆久久久国产精品免费| 亚洲电影视频在线| 国产清纯白嫩初高生在线观看91| 欧美在线观看禁18| 豆国产96在线|亚洲| 性久久久久久久| 国产精品蜜臀在线观看| 欧美va亚洲va在线观看蝴蝶网| 色先锋久久av资源部| 国产精品自在在线| 日本午夜一区二区| 一区二区在线观看av| 国产精品理论片| 国产亚洲成年网址在线观看| 日韩三级中文字幕| 精品视频在线视频| 在线日韩国产精品| 99精品久久99久久久久| av一区二区三区四区| 国产成人在线视频网址| 久久成人免费网站| 午夜欧美电影在线观看| 精品国产露脸精彩对白| 欧洲国产伦久久久久久久| 午夜a成v人精品| 欧美日韩午夜影院| 99久久精品免费观看| 国产九色sp调教91| 精品亚洲porn| 麻豆精品新av中文字幕| 视频一区欧美日韩| 另类中文字幕网| 美国十次综合导航| 精品系列免费在线观看| 奇米在线7777在线精品| 久久99热狠狠色一区二区| 麻豆91在线播放| 国产精品资源在线观看| 不卡av免费在线观看| 99国产麻豆精品| 欧美在线不卡一区| 欧美日韩免费观看一区三区| 欧美精品v日韩精品v韩国精品v| 欧美日韩午夜在线视频| 日韩欧美在线123| 麻豆国产精品官网| 精品美女在线播放| 色88888久久久久久影院按摩| 97aⅴ精品视频一二三区| 91福利视频网站| 欧美精品一卡二卡| 欧美变态tickling挠脚心| 欧美精品一区二区三区蜜桃视频| 久久欧美一区二区| 国产精品成人一区二区三区夜夜夜| 中文字幕欧美一| 亚洲va天堂va国产va久| 国精产品一区一区三区mba桃花| 成人黄色777网| 在线日韩一区二区| 精品国产伦一区二区三区观看方式 | 五月天丁香久久| 久久狠狠亚洲综合| 成人黄色电影在线| 欧美日韩一级片网站| 91精品国产高清一区二区三区| 精品999久久久| 亚洲精品视频一区| 日本特黄久久久高潮| 国产精品一品视频| 欧美午夜免费电影| 欧美videos大乳护士334| 亚洲男人的天堂在线aⅴ视频| 久久精品免费观看| 五月激情综合婷婷| 最新成人av在线| 午夜影视日本亚洲欧洲精品| 国产成人综合视频| 欧美久久婷婷综合色| 欧美激情自拍偷拍|