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

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

?? gf2x.c

?? 密碼大家Shoup寫的數(shù)論算法c語言實現(xiàn)
?? C
?? 第 1 頁 / 共 3 頁
字號:
   hl2[2] = hl2[2] ^ c[2];   hl2[3] = hl2[3] ^ c[3];      c[2] ^= hl2[0];   c[3] ^= hl2[1];   c[4] ^= hl2[2];   c[5] ^= hl2[3];}staticvoid mul4(_ntl_ulong *c, const _ntl_ulong *a, const _ntl_ulong *b){   _ntl_ulong hs0[2], hs1[2];   _ntl_ulong hl2[4];   hs0[0] = a[0] ^ a[2];   hs0[1] = a[1] ^ a[3];   hs1[0] = b[0] ^ b[2];   hs1[1] = b[1] ^ b[3];   mul2(c, a, b);   mul2(c+4, a+2, b+2);    mul2(hl2, hs0, hs1);   hl2[0] = hl2[0] ^ c[0] ^ c[4];   hl2[1] = hl2[1] ^ c[1] ^ c[5];   hl2[2] = hl2[2] ^ c[2] ^ c[6];   hl2[3] = hl2[3] ^ c[3] ^ c[7];      c[2] ^= hl2[0];   c[3] ^= hl2[1];   c[4] ^= hl2[2];   c[5] ^= hl2[3];}staticvoid mul5 (_ntl_ulong *c, const _ntl_ulong *a, const _ntl_ulong *b){   _ntl_ulong hs0[3], hs1[3];   _ntl_ulong hl2[6];   hs0[0] = a[0] ^ a[3];    hs0[1] = a[1] ^ a[4];   hs0[2] = a[2];   hs1[0] = b[0] ^ b[3];    hs1[1] = b[1] ^ b[4];   hs1[2] = b[2];   mul3(c, a, b);    mul2(c+6, a+3, b+3);    mul3(hl2, hs0, hs1);   hl2[0] = hl2[0] ^ c[0] ^ c[6];    hl2[1] = hl2[1] ^ c[1] ^ c[7];   hl2[2] = hl2[2] ^ c[2] ^ c[8];   hl2[3] = hl2[3] ^ c[3] ^ c[9];   hl2[4] = hl2[4] ^ c[4];   hl2[5] = hl2[5] ^ c[5];     c[3] ^= hl2[0];   c[4] ^= hl2[1];   c[5] ^= hl2[2];   c[6] ^= hl2[3];   c[7] ^= hl2[4];   c[8] ^= hl2[5];}staticvoid mul6(_ntl_ulong *c, const _ntl_ulong *a, const _ntl_ulong *b){   _ntl_ulong hs0[3], hs1[3];   _ntl_ulong hl2[6];   hs0[0] = a[0] ^ a[3];      hs0[1] = a[1] ^ a[4];   hs0[2] = a[2] ^ a[5];   hs1[0] = b[0] ^ b[3];      hs1[1] = b[1] ^ b[4];   hs1[2] = b[2] ^ b[5];   mul3(c, a, b);      mul3(c+6, a+3, b+3);    mul3(hl2, hs0, hs1);     hl2[0] = hl2[0] ^ c[0] ^ c[6];   hl2[1] = hl2[1] ^ c[1] ^ c[7];   hl2[2] = hl2[2] ^ c[2] ^ c[8];   hl2[3] = hl2[3] ^ c[3] ^ c[9];   hl2[4] = hl2[4] ^ c[4] ^ c[10];   hl2[5] = hl2[5] ^ c[5] ^ c[11];      c[3] ^= hl2[0];   c[4] ^= hl2[1];   c[5] ^= hl2[2];   c[6] ^= hl2[3];   c[7] ^= hl2[4];   c[8] ^= hl2[5];}staticvoid mul7(_ntl_ulong *c, const _ntl_ulong *a, const _ntl_ulong *b){   _ntl_ulong hs0[4], hs1[4];   _ntl_ulong hl2[8];   hs0[0] = a[0] ^ a[4];    hs0[1] = a[1] ^ a[5];   hs0[2] = a[2] ^ a[6];   hs0[3] = a[3];   hs1[0] = b[0] ^ b[4];    hs1[1] = b[1] ^ b[5];   hs1[2] = b[2] ^ b[6];   hs1[3] = b[3];   mul4(c, a, b);    mul3(c+8, a+4, b+4);    mul4(hl2, hs0, hs1);   hl2[0] = hl2[0] ^ c[0] ^ c[8];   hl2[1] = hl2[1] ^ c[1] ^ c[9];   hl2[2] = hl2[2] ^ c[2] ^ c[10];   hl2[3] = hl2[3] ^ c[3] ^ c[11];   hl2[4] = hl2[4] ^ c[4] ^ c[12];   hl2[5] = hl2[5] ^ c[5] ^ c[13];   hl2[6] = hl2[6] ^ c[6];   hl2[7] = hl2[7] ^ c[7];      c[4]  ^= hl2[0];   c[5]  ^= hl2[1];   c[6]  ^= hl2[2];   c[7]  ^= hl2[3];   c[8]  ^= hl2[4];   c[9]  ^= hl2[5];   c[10] ^= hl2[6];   c[11] ^= hl2[7];}staticvoid mul8(_ntl_ulong *c, const _ntl_ulong *a, const _ntl_ulong *b){   _ntl_ulong hs0[4], hs1[4];   _ntl_ulong hl2[8];   hs0[0] = a[0] ^ a[4];    hs0[1] = a[1] ^ a[5];   hs0[2] = a[2] ^ a[6];   hs0[3] = a[3] ^ a[7];   hs1[0] = b[0] ^ b[4];    hs1[1] = b[1] ^ b[5];   hs1[2] = b[2] ^ b[6];   hs1[3] = b[3] ^ b[7];   mul4(c, a, b);    mul4(c+8, a+4, b+4);   mul4(hl2, hs0, hs1);    hl2[0] = hl2[0] ^ c[0] ^ c[8];   hl2[1] = hl2[1] ^ c[1] ^ c[9];   hl2[2] = hl2[2] ^ c[2] ^ c[10];   hl2[3] = hl2[3] ^ c[3] ^ c[11];   hl2[4] = hl2[4] ^ c[4] ^ c[12];   hl2[5] = hl2[5] ^ c[5] ^ c[13];   hl2[6] = hl2[6] ^ c[6] ^ c[14];   hl2[7] = hl2[7] ^ c[7] ^ c[15];      c[4]  ^= hl2[0];   c[5]  ^= hl2[1];   c[6]  ^= hl2[2];   c[7]  ^= hl2[3];   c[8]  ^= hl2[4];   c[9]  ^= hl2[5];   c[10] ^= hl2[6];   c[11] ^= hl2[7];}staticvoid KarMul(_ntl_ulong *c, const _ntl_ulong *a, const _ntl_ulong *b, long len, _ntl_ulong *stk){   if (len <= 8) {      switch (len) {         case 1: mul1(c, a[0], b[0]); break;         case 2: mul2(c, a, b); break;         case 3: mul3(c, a, b); break;         case 4: mul4(c, a, b); break;         case 5: mul5(c, a, b); break;         case 6: mul6(c, a, b); break;         case 7: mul7(c, a, b); break;         case 8: mul8(c, a, b); break;      }      return;   }   long ll, lh, i, ll2, lh2;   const _ntl_ulong *a0, *a1, *b0, *b1;   _ntl_ulong *a01, *b01, *h;   lh = len >> 1;   ll = (len+1) >> 1;   ll2 = ll << 1;   lh2 = lh << 1;   a01 = stk;  stk += ll+1;   b01 = stk;  stk += ll+1;   h = stk; stk += ll2+1;   a0 = a;   a1 = a+ll;   b0 = b;   b1 = b+ll;   KarMul(c, a0, b0, ll, stk);   KarMul(c+ll2, a1, b1, lh, stk);   for (i = 0; i < lh; i++) {      a01[i] = a[i] ^ a[i+ll];      b01[i] = b[i] ^ b[i+ll];   }   if (lh < ll) {      a01[lh] = a[lh];      b01[lh] = b[lh];   }   KarMul(h, a01, b01, ll, stk);   for (i = 0; i < ll2; i++)      h[i] ^= c[i];   for (i = 0; i < lh2; i++)      h[i] ^= c[i+ll2];   for (i = 0; i < ll2; i++)      c[i+ll] ^= h[i];}void mul(GF2X& c, const GF2X& a, const GF2X& b){   long sa = a.xrep.length();   long sb = b.xrep.length();   if (sa <= 0 || sb <= 0) {      clear(c);      return;   }    _ntl_ulong a0 = a.xrep[0];   _ntl_ulong b0 = b.xrep[0];   if (sb == 1 && b0 == 1) {      c = a;      return;   }   if (sa == 1 && a0 == 1) {      c = b;      return;   }   if (&a == &b) {      sqr(c, a);      return;   }   if (sa == sb && sa <= 8) {      // we treat these cases specially for efficiency reasons      switch (sa) {         case 1: {            _ntl_ulong v[2];            if (!(a0 >> NTL_BITS_PER_LONG/2))               mul_half(v, b0, a0);            else if (!(b0 >> NTL_BITS_PER_LONG/2))               mul_half(v, a0, b0);            else               mul1(v, a0, b0);            if (v[1]) {               c.xrep.SetLength(2);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];            }            else {               c.xrep.SetLength(1);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];            }         }         return;         case 2: {            _ntl_ulong v[4];            mul2(v, &a.xrep[0], &b.xrep[0]);            if (v[3]) {               c.xrep.SetLength(4);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];            }            else {               c.xrep.SetLength(3);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];            }         }         return;         case 3: {            _ntl_ulong v[6];            mul3(v, &a.xrep[0], &b.xrep[0]);            if (v[5]) {               c.xrep.SetLength(6);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];               cp[4] = v[4];               cp[5] = v[5];            }            else {               c.xrep.SetLength(5);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];               cp[4] = v[4];            }         }         return;         case 4: {            _ntl_ulong v[8];            mul4(v, &a.xrep[0], &b.xrep[0]);            if (v[7]) {               c.xrep.SetLength(8);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];               cp[4] = v[4];               cp[5] = v[5];               cp[6] = v[6];               cp[7] = v[7];            }            else {               c.xrep.SetLength(7);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];               cp[4] = v[4];               cp[5] = v[5];               cp[6] = v[6];            }         }         return;         case 5: {            _ntl_ulong v[10];            mul5(v, &a.xrep[0], &b.xrep[0]);            if (v[9]) {               c.xrep.SetLength(10);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];               cp[4] = v[4];               cp[5] = v[5];               cp[6] = v[6];               cp[7] = v[7];               cp[8] = v[8];               cp[9] = v[9];            }            else {               c.xrep.SetLength(9);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];               cp[4] = v[4];               cp[5] = v[5];               cp[6] = v[6];               cp[7] = v[7];               cp[8] = v[8];            }         }         return;         case 6: {            _ntl_ulong v[12];            mul6(v, &a.xrep[0], &b.xrep[0]);            if (v[11]) {               c.xrep.SetLength(12);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];               cp[4] = v[4];               cp[5] = v[5];               cp[6] = v[6];               cp[7] = v[7];               cp[8] = v[8];               cp[9] = v[9];               cp[10] = v[10];               cp[11] = v[11];            }            else {               c.xrep.SetLength(11);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];               cp[4] = v[4];               cp[5] = v[5];               cp[6] = v[6];               cp[7] = v[7];               cp[8] = v[8];               cp[9] = v[9];               cp[10] = v[10];            }         }         return;          case 7: {            _ntl_ulong v[14];            mul7(v, &a.xrep[0], &b.xrep[0]);            if (v[13]) {               c.xrep.SetLength(14);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];               cp[4] = v[4];               cp[5] = v[5];               cp[6] = v[6];               cp[7] = v[7];               cp[8] = v[8];               cp[9] = v[9];               cp[10] = v[10];               cp[11] = v[11];               cp[12] = v[12];               cp[13] = v[13];            }            else {               c.xrep.SetLength(13);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];               cp[4] = v[4];               cp[5] = v[5];               cp[6] = v[6];               cp[7] = v[7];               cp[8] = v[8];               cp[9] = v[9];               cp[10] = v[10];               cp[11] = v[11];               cp[12] = v[12];            }         }         return;          case 8: {            _ntl_ulong v[16];            mul8(v, &a.xrep[0], &b.xrep[0]);            if (v[15]) {               c.xrep.SetLength(16);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];               cp[4] = v[4];               cp[5] = v[5];               cp[6] = v[6];               cp[7] = v[7];               cp[8] = v[8];               cp[9] = v[9];               cp[10] = v[10];               cp[11] = v[11];               cp[12] = v[12];               cp[13] = v[13];               cp[14] = v[14];               cp[15] = v[15];            }            else {               c.xrep.SetLength(15);               _ntl_ulong *cp = &c.xrep[0];               cp[0] = v[0];               cp[1] = v[1];               cp[2] = v[2];               cp[3] = v[3];               cp[4] = v[4];               cp[5] = v[5];               cp[6] = v[6];               cp[7] = v[7];               cp[8] = v[8];               cp[9] = v[9];               cp[10] = v[10];               cp[11] = v[11];               cp[12] = v[12];               cp[13] = v[13];               cp[14] = v[14];            }         }         return;       }   }   // another special case:  one of the two inputs   // has length 1 (and maybe 1/2).   if (sa == 1) {      c.xrep.SetLength(sb + 1);      _ntl_ulong *cp = c.xrep.elts();      const _ntl_ulong *bp = b.xrep.elts();      long i;      _ntl_ulong carry;      _ntl_ulong v[2];      carry = 0;      if (a0 >> NTL_BITS_PER_LONG/2) {         for (i = 0; i < sb; i++) {            mul1(v, bp[i], a0);            cp[i] = carry ^ v[0];            carry = v[1];         }      }      else {         for (i = 0; i < sb; i++) {            mul_half(v, bp[i], a0);            cp[i] = carry ^ v[0];            carry = v[1];         }      }      cp[sb] = carry;      c.normalize();      return;   }   if (sb == 1) {      c.xrep.SetLength(sa + 1);      _ntl_ulong *cp = c.xrep.elts();      const _ntl_ulong *ap = a.xrep.elts();      long i;      _ntl_ulong carry;      _ntl_ulong v[2];      carry = 0;      if (b0 >> NTL_BITS_PER_LONG/2) {         for (i = 0; i < sa; i++) {            mul1(v, ap[i], b0);            cp[i] = carry ^ v[0];            carry = v[1];         }      }      else {         for (i = 0; i < sa; i++) {            mul_half(v, ap[i], b0);            cp[i] = carry ^ v[0];            carry = v[1];         }      }      cp[sa] = carry;      c.normalize();      return;   }   // finally: the general case      static WordVector mem;   static WordVector stk;   static WordVector vec;   const _ntl_ulong *ap, *bp;   _ntl_ulong *cp;   long sc = sa + sb;   long in_mem = 0;   if (&a == &c || &b == &c) {      mem.SetLength(sc);      cp = mem.elts();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美激情一区二区| 成人av资源在线观看| 午夜精品久久久久久久久久久| 中文字幕成人av| 久久久久国产成人精品亚洲午夜| 日韩情涩欧美日韩视频| 欧美一级欧美三级在线观看| 在线成人av影院| 国产在线精品不卡| 国产精品免费看片| 中文字幕一区二区三区蜜月| 国产日产欧产精品推荐色| 26uuu国产在线精品一区二区| 26uuu国产在线精品一区二区| 精品国产免费一区二区三区香蕉| 精品电影一区二区| 久久精品视频免费观看| 国产欧美精品一区二区色综合朱莉| 久久久久久99精品| 国产精品久久久久久户外露出| 综合婷婷亚洲小说| 亚洲国产一区视频| 奇米影视7777精品一区二区| 久国产精品韩国三级视频| 国产精品一区二区x88av| gogogo免费视频观看亚洲一| 色狠狠一区二区三区香蕉| 在线免费观看成人短视频| 精品婷婷伊人一区三区三| 欧美一级淫片007| 国产婷婷色一区二区三区四区| 中文字幕中文字幕在线一区| 一区二区三区.www| 美女精品一区二区| 国产成人免费xxxxxxxx| 色菇凉天天综合网| 日韩精品最新网址| 国产精品久久久久久久久久免费看 | 国产在线日韩欧美| 99久久国产免费看| 欧美日韩一区二区三区视频| 精品久久久久久久人人人人传媒 | 欧美影院精品一区| 日韩欧美高清一区| 亚洲欧洲制服丝袜| 日本不卡视频一二三区| 大桥未久av一区二区三区中文| 91视频.com| 欧美v国产在线一区二区三区| 亚洲欧洲日本在线| 日本aⅴ亚洲精品中文乱码| 成人爱爱电影网址| 日韩一二三四区| 亚洲视频1区2区| 国产一区二区三区四区在线观看| 色狠狠色狠狠综合| 国产视频一区二区在线| 舔着乳尖日韩一区| 91在线视频播放地址| 日韩精品一区二区三区蜜臀 | 欧美老女人在线| 国产精品白丝在线| 欧美影院精品一区| 天天综合天天做天天综合| 韩国成人福利片在线播放| 欧美综合天天夜夜久久| 久久免费的精品国产v∧| 亚洲福利视频一区| 成人妖精视频yjsp地址| 欧美一区二区国产| 一区二区三区四区视频精品免费 | 成人aaaa免费全部观看| 日韩美女视频在线| 午夜影院在线观看欧美| 不卡一卡二卡三乱码免费网站| 26uuu亚洲综合色| 日韩高清欧美激情| 欧美综合一区二区三区| 中文字幕一区二区三| 国产一区二区三区在线观看免费视频| 欧美日韩国产一区二区三区地区| 国产精品国产精品国产专区不蜜| 国产一区二区三区香蕉| 日韩一区二区在线观看视频| 亚洲国产综合在线| 一本大道久久精品懂色aⅴ| 欧美经典一区二区| 国内成人免费视频| 日韩视频在线你懂得| 视频在线观看一区二区三区| 欧洲中文字幕精品| 一区二区在线观看免费视频播放| 成人精品国产福利| 国产精品欧美综合在线| 国产成人午夜电影网| 久久综合av免费| 久久99最新地址| 欧美mv日韩mv亚洲| 久久精品72免费观看| 日韩欧美国产综合| 久久精品理论片| 精品福利一区二区三区免费视频| 久久99久久久久久久久久久| 7777精品久久久大香线蕉| 午夜影院在线观看欧美| 欧美日韩免费观看一区三区| 亚洲一区二区三区四区不卡| 欧美亚洲一区二区在线观看| 亚洲综合图片区| 欧美日韩中文一区| 日韩av中文字幕一区二区三区| 欧美日韩电影一区| 蜜桃一区二区三区在线观看| 欧美本精品男人aⅴ天堂| 精品一区二区国语对白| 久久久激情视频| 成人av网站在线| 一区二区三区四区av| 欧美日韩一区二区欧美激情| 日韩av一级片| 久久影音资源网| 国产一区二区三区综合| 国产精品久久久久一区二区三区共| av成人免费在线观看| 一卡二卡三卡日韩欧美| 免费在线看成人av| 色综合久久综合网欧美综合网| 亚洲精品一二三| 欧美精选在线播放| 精品一区二区三区免费| 欧美国产精品一区二区| 色菇凉天天综合网| 免费在线看成人av| 国产人久久人人人人爽| 色综合久久88色综合天天免费| 亚洲v中文字幕| 久久亚洲一区二区三区四区| 97se亚洲国产综合在线| 午夜电影网一区| 国产亚洲欧美激情| 一本一道久久a久久精品综合蜜臀| 香蕉成人伊视频在线观看| 欧美精品一区二区三区高清aⅴ| 成人午夜电影网站| 午夜激情久久久| 欧美极品aⅴ影院| 欧美日韩大陆一区二区| 国产一区啦啦啦在线观看| 亚洲乱码精品一二三四区日韩在线| 欧美精品日韩一区| 成人精品免费看| 日韩制服丝袜先锋影音| 久久精品免费在线观看| 欧美三区在线视频| 国产精品一区二区在线看| 亚洲香蕉伊在人在线观| www国产亚洲精品久久麻豆| 91久久奴性调教| 国产综合久久久久久鬼色| 一区二区三区在线观看动漫| 久久综合av免费| 欧美日韩一二三区| 国产91在线看| 五月天丁香久久| 国产精品三级av| 欧美电影免费观看高清完整版在线 | 久久精品国产亚洲一区二区三区 | 国产电影精品久久禁18| 亚洲gay无套男同| 国产精品久久久久影院亚瑟| 日韩一区二区三区免费看| 色婷婷亚洲综合| 成人久久久精品乱码一区二区三区| 日本在线不卡视频| 一区二区三区在线免费视频| 国产人成一区二区三区影院| 91精品久久久久久久99蜜桃 | 欧美日韩高清不卡| 97精品国产97久久久久久久久久久久 | 亚洲成人自拍网| 亚洲日本免费电影| 亚洲国产岛国毛片在线| 日韩一区二区在线观看视频播放| 在线观看亚洲成人| 91麻豆精品一区二区三区| 国产美女视频91| 精品一区二区在线免费观看| 丝袜美腿亚洲色图| 亚洲午夜三级在线| 亚洲蜜臀av乱码久久精品| 国产欧美精品在线观看| 久久综合狠狠综合| 2023国产精品视频| 欧美sm极限捆绑bd| 欧美va亚洲va| 国产一区二区三区精品视频| 日本色综合中文字幕| 亚洲综合成人网| 一区二区免费视频| 一区二区三区中文免费|