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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? vec_gf2.h

?? 可以根據NTL庫進RSA加密、解密算法的實現
?? H
字號:

#ifndef NTL_vec_GF2__H
#define NTL_vec_GF2__H

#include <NTL/WordVector.h>
#include <NTL/GF2.h>

NTL_OPEN_NNS

class vec_GF2;

class subscript_GF2 {
public:
   vec_GF2& v;
   long i;

   subscript_GF2(vec_GF2& vv, long ii) : v(vv), i(ii) { }

   inline const subscript_GF2& operator=(const subscript_GF2&) const;
   inline const subscript_GF2& operator=(GF2) const;
   inline const subscript_GF2& operator=(long) const;

   inline operator GF2() const;
};

class const_subscript_GF2 {
public:
   const vec_GF2& v;
   long i;

   const_subscript_GF2(const vec_GF2& vv, long ii) : v(vv), i(ii) { }

   inline operator GF2() const;

private:
   void operator=(const const_subscript_GF2&); // disabled

};
   

class vec_GF2 {

public:

// these should be private, but they are not

   WordVector rep;

   long _len;  // length (in bits)
   long _maxlen;  // (MaxLength << 1) | (fixed)

   // invariants: rep.length() "tracks" length() ( = _len)
   //             All bits in positions >= length are zero.

   // Note:       rep.MaxLength() may exceed the value
   //             indicated by MaxLength().
   

//the following are "really" public


   vec_GF2() : _len(0), _maxlen(0) {}
   vec_GF2(INIT_SIZE_TYPE, long n) : _len(0), _maxlen(0) { SetLength(n); }
   vec_GF2(const vec_GF2& a) : _len(0), _maxlen(0) { *this = a; }

   vec_GF2& operator=(const vec_GF2& a);

   ~vec_GF2() {}

   void kill();

   void SetLength(long n);
   void SetMaxLength(long n);
   void FixLength(long n);

   long length() const { return _len; }
   long MaxLength() const { return _maxlen >> 1; }  
   long allocated() const { return rep.MaxLength() * NTL_BITS_PER_LONG; }
   long fixed() const { return _maxlen & 1; }


   vec_GF2(vec_GF2& x, INIT_TRANS_TYPE) : 
      rep(x.rep, INIT_TRANS), _len(x._len), _maxlen(x._maxlen) { }

   GF2 get(long i) const;
   void put(long i, GF2 a);
   void put(long i, long a) { put(i, to_GF2(a)); }

   subscript_GF2 operator[](long i) 
      { return subscript_GF2(*this, i); }

   subscript_GF2 operator()(long i) 
      { return subscript_GF2(*this, i-1); }

   const_subscript_GF2 operator[](long i) const 
      { return const_subscript_GF2(*this, i); }

   const_subscript_GF2 operator()(long i) const 
      { return const_subscript_GF2(*this, i-1); }

};

inline subscript_GF2::operator GF2() const
{
   return v.get(i);
}

inline const_subscript_GF2::operator GF2() const
{
   return v.get(i);
}

inline const subscript_GF2& 
   subscript_GF2::operator=(const subscript_GF2& a) const
   { v.put(i, a.v.get(a.i));  return *this; }

inline const subscript_GF2& 
   subscript_GF2::operator=(GF2 a) const
   { v.put(i, a);  return *this; }

inline const subscript_GF2& 
   subscript_GF2::operator=(long a) const
   { v.put(i, a);  return *this; }

inline const subscript_GF2& operator+=(const subscript_GF2& x, GF2 b)
   { x = x + b; return x; }  

inline const subscript_GF2& operator+=(const subscript_GF2& x, long b)
   { x = x + b; return x; }  

inline const subscript_GF2& operator-=(const subscript_GF2& x, GF2 b)
   { x = x - b; return x; }  

inline const subscript_GF2& operator-=(const subscript_GF2& x, long b)
   { x = x - b; return x; }  

inline const subscript_GF2& operator*=(const subscript_GF2& x, GF2 b)
   { x = x * b; return x; }  

inline const subscript_GF2& operator*=(const subscript_GF2& x, long b)
   { x = x * b; return x; }  

inline const subscript_GF2& operator/=(const subscript_GF2& x, GF2 b)
   { x = x / b; return x; }  

inline const subscript_GF2& operator/=(const subscript_GF2& x, long b)
   { x = x / b; return x; }  

inline const subscript_GF2& operator++(const subscript_GF2& x) 
   { x = x + 1; return x; }

inline void operator++(const subscript_GF2& x, int) 
   { x = x + 1; }

inline const subscript_GF2& operator--(const subscript_GF2& x) 
   { x = x - 1; return x; }

inline void operator--(const subscript_GF2& x, int) 
   { x = x - 1; }

void swap(vec_GF2& x, vec_GF2& y);
void append(vec_GF2& v, GF2 a);
void append(vec_GF2& v, const vec_GF2& a);

long operator==(const vec_GF2& a, const vec_GF2& b);
inline long operator!=(const vec_GF2& a, const vec_GF2& b)
   { return !(a == b); }

NTL_SNS ostream& operator<<(NTL_SNS ostream& s, const vec_GF2& a);
NTL_SNS istream& operator>>(NTL_SNS istream& s, vec_GF2& a);

void shift(vec_GF2& x, const vec_GF2& a, long n);
// x = a shifted n places, i.e., if l = a.length(),
//    x.length() = l, x[i] = a[i-n] for 0 <= i-n < l,
//    and x[i] = 0 for all other i such that 0 <= i < l.

inline vec_GF2 shift(const vec_GF2& a, long n)
   { vec_GF2 x; shift(x, a, n); NTL_OPT_RETURN(vec_GF2, x); }

void reverse(vec_GF2& x, const vec_GF2& a);

inline vec_GF2 reverse(const vec_GF2& a)
   { vec_GF2 x; reverse(x, a); NTL_OPT_RETURN(vec_GF2, x); }

void random(vec_GF2& x, long n);
inline vec_GF2 random_vec_GF2(long n)
   { vec_GF2 x; random(x, n); NTL_OPT_RETURN(vec_GF2, x); }

long weight(const vec_GF2& a);

void mul(vec_GF2& x, const vec_GF2& a, GF2 b);
inline void mul(vec_GF2& x, GF2 a, const vec_GF2& b)
   { mul(x, b, a); }

inline void mul(vec_GF2& x, const vec_GF2& a, long b)
   { mul(x, a, to_GF2(b)); }
inline void mul(vec_GF2& x, long a, const vec_GF2& b)
   { mul(x, b, a); }

void add(vec_GF2& x, const vec_GF2& a, const vec_GF2& b);

inline void sub(vec_GF2& x, const vec_GF2& a, const vec_GF2& b)
   { add(x, a, b); }

void clear(vec_GF2& x);

inline void negate(vec_GF2& x, const vec_GF2& a)
   { x = a; }

inline void InnerProduct(GF2& x, const vec_GF2& a, const vec_GF2& b)
   { x = to_GF2(InnerProduct(a.rep, b.rep)); }

long IsZero(const vec_GF2& a);

vec_GF2 operator+(const vec_GF2& a, const vec_GF2& b);

vec_GF2 operator-(const vec_GF2& a, const vec_GF2& b);

inline vec_GF2 operator-(const vec_GF2& a)
   { return a; }

inline vec_GF2 operator*(const vec_GF2& a, GF2 b)
   { vec_GF2 x; mul(x, a, b); NTL_OPT_RETURN(vec_GF2, x); }

inline vec_GF2 operator*(const vec_GF2& a, long b)
   { vec_GF2 x; mul(x, a, b); NTL_OPT_RETURN(vec_GF2, x); }

inline vec_GF2 operator*(GF2 a, const vec_GF2& b)
   { vec_GF2 x; mul(x, a, b); NTL_OPT_RETURN(vec_GF2, x); }

inline vec_GF2 operator*(long a, const vec_GF2& b)
   { vec_GF2 x; mul(x, a, b); NTL_OPT_RETURN(vec_GF2, x); }


inline GF2 operator*(const vec_GF2& a, const vec_GF2& b)
   { return to_GF2(InnerProduct(a.rep, b.rep)); }

// assignment operator notation:

inline vec_GF2& operator+=(vec_GF2& x, const vec_GF2& a)
{ 
   add(x, x, a);
   return x;
}

inline vec_GF2& operator-=(vec_GF2& x, const vec_GF2& a)
{ 
   sub(x, x, a);
   return x;
}

inline vec_GF2& operator*=(vec_GF2& x, GF2 a)
{ 
   mul(x, x, a);
   return x;
}

inline vec_GF2& operator*=(vec_GF2& x, long a)
{ 
   mul(x, x, a);
   return x;
}

void VectorCopy(vec_GF2& x, const vec_GF2& a, long n);
inline vec_GF2 VectorCopy(const vec_GF2& a, long n)
   { vec_GF2 x; VectorCopy(x, a, n); NTL_OPT_RETURN(vec_GF2, x); }

NTL_CLOSE_NNS


#endif


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区在线播放相泽| 一本在线高清不卡dvd| 成人国产精品免费观看| 欧美一二三四区在线| 亚洲裸体在线观看| 国产成人免费视| 日韩免费看的电影| 亚洲国产一区二区在线播放| 99国产精品久久久久久久久久 | 亚洲图片你懂的| 蜜桃av噜噜一区| 欧美日韩国产综合一区二区三区| 亚洲欧洲日韩在线| 成人手机在线视频| 久久精品在线观看| 国产精品18久久久久| 日韩欧美国产午夜精品| 日欧美一区二区| 欧美视频在线播放| 亚洲五码中文字幕| 欧美午夜在线一二页| 亚洲狠狠丁香婷婷综合久久久| 成人av电影在线| 成人欧美一区二区三区| 成人免费视频视频在线观看免费| 久久久青草青青国产亚洲免观| 久久99精品久久久久久动态图 | 国产日产亚洲精品系列| 另类小说色综合网站| 欧美一区二区三区喷汁尤物| 午夜精品视频一区| 91精品国产综合久久香蕉的特点| 亚洲成av人影院在线观看网| 欧美日韩美少妇| 无码av免费一区二区三区试看| 欧美精品欧美精品系列| 日本伊人色综合网| 欧美成人一区二区三区片免费| 激情亚洲综合在线| 国产人伦精品一区二区| 不卡的av电影| 亚洲第一主播视频| 日韩一区二区三区电影在线观看| 另类小说视频一区二区| 国产亚洲一二三区| 成a人片亚洲日本久久| 亚洲色图视频免费播放| 欧美亚一区二区| 久久成人精品无人区| 久久久久久久久伊人| av亚洲精华国产精华精华| 亚洲精品五月天| 欧美日韩卡一卡二| 国产剧情一区在线| 亚洲婷婷在线视频| 69堂亚洲精品首页| 国产美女视频91| 中文字幕在线观看不卡视频| 欧美日韩精品一区二区三区四区 | 精品国产乱码久久久久久1区2区 | 国产偷国产偷亚洲高清人白洁| 成人高清视频免费观看| 午夜影院在线观看欧美| 精品日韩av一区二区| 99久久99久久精品免费观看| 日韩精品亚洲专区| 国产精品无码永久免费888| 在线观看成人小视频| 国产一区二区福利视频| 亚洲激情欧美激情| 久久久99久久| 欧美日本国产一区| av电影在线观看一区| 日本美女视频一区二区| 中文字幕在线一区免费| 日韩欧美国产综合一区 | 欧美性大战久久久久久久| 国产一区二区三区精品欧美日韩一区二区三区 | 日本不卡一二三| 国产精品欧美极品| 欧美成人性战久久| 精品婷婷伊人一区三区三| 国产精品77777| 日本成人在线网站| 一区二区三区免费在线观看| 久久免费偷拍视频| 日韩无一区二区| 欧美日韩中字一区| 色屁屁一区二区| 成人av集中营| 国产酒店精品激情| 激情五月播播久久久精品| 午夜亚洲国产au精品一区二区| 中文无字幕一区二区三区| 日韩三级在线观看| 欧美日韩另类一区| 欧美视频一区二区在线观看| 不卡的av电影| 不卡的av中国片| 国产成a人亚洲| 国产一区二区在线看| 奇米在线7777在线精品| 天天综合网 天天综合色| 亚洲男人都懂的| 中文字幕一区二区三区蜜月| 国产日产亚洲精品系列| 国产色爱av资源综合区| 精品国产电影一区二区| 日韩欧美不卡一区| 欧美zozozo| 久久久影院官网| 久久精品视频网| 久久久久88色偷偷免费| 国产欧美一区二区精品忘忧草| 2021国产精品久久精品| 国产午夜精品福利| 欧美国产精品专区| 国产精品美女视频| 亚洲免费毛片网站| 亚洲va国产va欧美va观看| 日韩精品色哟哟| 激情国产一区二区| 东方aⅴ免费观看久久av| 懂色av一区二区三区蜜臀| 9i在线看片成人免费| 91啦中文在线观看| 欧美影视一区二区三区| 91精品国产91综合久久蜜臀| 日韩免费看网站| 欧美激情资源网| 亚洲精品videosex极品| 日韩精品国产欧美| 国产伦精品一区二区三区视频青涩 | 精品福利视频一区二区三区| www国产成人免费观看视频 深夜成人网| 久久天堂av综合合色蜜桃网| 中文欧美字幕免费| 亚洲小说春色综合另类电影| 水野朝阳av一区二区三区| 黄一区二区三区| 色哟哟欧美精品| 日韩亚洲欧美高清| 中文字幕一区免费在线观看| 亚洲乱码一区二区三区在线观看| 日日夜夜一区二区| 国产福利电影一区二区三区| 在线观看国产日韩| 久久综合久久99| 一区二区三区久久| 久久99精品国产.久久久久久| 99久久久国产精品| 777色狠狠一区二区三区| 国产欧美日韩三级| 日韩成人精品在线| 成人97人人超碰人人99| 日韩欧美一卡二卡| 日韩一区欧美一区| 久久国产精品72免费观看| 成人av资源在线观看| 91麻豆精品国产91久久久资源速度 | 99久久免费国产| 日韩一区二区免费在线观看| 自拍偷拍欧美激情| 久久机这里只有精品| 在线免费av一区| 国产日本一区二区| 蜜臀久久99精品久久久久宅男| 北岛玲一区二区三区四区| 91麻豆精品国产91久久久资源速度| 国产精品国产自产拍在线| 蜜臀久久久99精品久久久久久| 91日韩在线专区| 国产日韩精品视频一区| 日韩精品高清不卡| 日本高清不卡视频| 中文字幕二三区不卡| 精品一区二区在线免费观看| 欧美猛男男办公室激情| 亚洲人成在线播放网站岛国| 国产91清纯白嫩初高中在线观看 | 欧美猛男超大videosgay| 中文字幕永久在线不卡| 国产成人免费9x9x人网站视频| 日韩一区二区视频在线观看| 午夜精品久久久久影视| 色天天综合久久久久综合片| 日本一区二区电影| 成人午夜碰碰视频| 久久久国产精品午夜一区ai换脸| 精品影院一区二区久久久| 欧美一级二级在线观看| 午夜欧美2019年伦理| 欧美丝袜丝交足nylons| 一区二区三区产品免费精品久久75| 北条麻妃一区二区三区| 中文字幕一区在线观看| 99国产精品久久久久久久久久| 中文字幕中文字幕一区二区| jlzzjlzz亚洲日本少妇| 18欧美乱大交hd1984|