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

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

?? nbtheory.h

?? 此文件是實現加解密算法的函數庫
?? H
字號:
// nbtheory.h - written and placed in the public domain by Wei Dai

#ifndef CRYPTOPP_NBTHEORY_H
#define CRYPTOPP_NBTHEORY_H

#include "integer.h"
#include "algparam.h"

NAMESPACE_BEGIN(CryptoPP)

// export a table of small primes
extern const unsigned int maxPrimeTableSize;
extern const word lastSmallPrime;
extern unsigned int primeTableSize;
extern word primeTable[];

// build up the table to maxPrimeTableSize
void BuildPrimeTable();

// ************ primality testing ****************

// generate a provable prime
Integer MaurerProvablePrime(RandomNumberGenerator &rng, unsigned int bits);
Integer MihailescuProvablePrime(RandomNumberGenerator &rng, unsigned int bits);

bool IsSmallPrime(const Integer &p);

// returns true if p is divisible by some prime less than bound
// bound not be greater than the largest entry in the prime table
bool TrialDivision(const Integer &p, unsigned bound);

// returns true if p is NOT divisible by small primes
bool SmallDivisorsTest(const Integer &p);

// These is no reason to use these two, use the ones below instead
bool IsFermatProbablePrime(const Integer &n, const Integer &b);
bool IsLucasProbablePrime(const Integer &n);

bool IsStrongProbablePrime(const Integer &n, const Integer &b);
bool IsStrongLucasProbablePrime(const Integer &n);

// Rabin-Miller primality test, i.e. repeating the strong probable prime test 
// for several rounds with random bases
bool RabinMillerTest(RandomNumberGenerator &rng, const Integer &w, unsigned int rounds);

// primality test, used to generate primes
bool IsPrime(const Integer &p);

// more reliable than IsPrime(), used to verify primes generated by others
bool VerifyPrime(RandomNumberGenerator &rng, const Integer &p, unsigned int level = 1);

class PrimeSelector
{
public:
	const PrimeSelector *GetSelectorPointer() const {return this;}
	virtual bool IsAcceptable(const Integer &candidate) const =0;
};

// use a fast sieve to find the first probable prime in {x | p<=x<=max and x%mod==equiv}
// returns true iff successful, value of p is undefined if no such prime exists
bool FirstPrime(Integer &p, const Integer &max, const Integer &equiv, const Integer &mod, const PrimeSelector *pSelector);

unsigned int PrimeSearchInterval(const Integer &max);

AlgorithmParameters<AlgorithmParameters<AlgorithmParameters<NullNameValuePairs, Integer::RandomNumberType>, Integer>, Integer>
	MakeParametersForTwoPrimesOfEqualSize(unsigned int productBitLength);

// ********** other number theoretic functions ************

inline Integer GCD(const Integer &a, const Integer &b)
	{return Integer::Gcd(a,b);}
inline bool RelativelyPrime(const Integer &a, const Integer &b)
	{return Integer::Gcd(a,b) == Integer::One();}
inline Integer LCM(const Integer &a, const Integer &b)
	{return a/Integer::Gcd(a,b)*b;}
inline Integer EuclideanMultiplicativeInverse(const Integer &a, const Integer &b)
	{return a.InverseMod(b);}

// use Chinese Remainder Theorem to calculate x given x mod p and x mod q
Integer CRT(const Integer &xp, const Integer &p, const Integer &xq, const Integer &q);
// use this one if u = inverse of p mod q has been precalculated
Integer CRT(const Integer &xp, const Integer &p, const Integer &xq, const Integer &q, const Integer &u);

// if b is prime, then Jacobi(a, b) returns 0 if a%b==0, 1 if a is quadratic residue mod b, -1 otherwise
// check a number theory book for what Jacobi symbol means when b is not prime
int Jacobi(const Integer &a, const Integer &b);

// calculates the Lucas function V_e(p, 1) mod n
Integer Lucas(const Integer &e, const Integer &p, const Integer &n);
// calculates x such that m==Lucas(e, x, p*q), p q primes
Integer InverseLucas(const Integer &e, const Integer &m, const Integer &p, const Integer &q);
// use this one if u=inverse of p mod q has been precalculated
Integer InverseLucas(const Integer &e, const Integer &m, const Integer &p, const Integer &q, const Integer &u);

inline Integer ModularExponentiation(const Integer &a, const Integer &e, const Integer &m)
	{return a_exp_b_mod_c(a, e, m);}
// returns x such that x*x%p == a, p prime
Integer ModularSquareRoot(const Integer &a, const Integer &p);
// returns x such that a==ModularExponentiation(x, e, p*q), p q primes,
// and e relatively prime to (p-1)*(q-1)
Integer ModularRoot(const Integer &a, const Integer &e, const Integer &p, const Integer &q);
// use this one if dp=d%(p-1), dq=d%(q-1), (d is inverse of e mod (p-1)*(q-1))
// and u=inverse of p mod q have been precalculated
Integer ModularRoot(const Integer &a, const Integer &dp, const Integer &dq, const Integer &p, const Integer &q, const Integer &u);

// find r1 and r2 such that ax^2 + bx + c == 0 (mod p) for x in {r1, r2}, p prime
// returns true if solutions exist
bool SolveModularQuadraticEquation(Integer &r1, Integer &r2, const Integer &a, const Integer &b, const Integer &c, const Integer &p);

// returns log base 2 of estimated number of operations to calculate discrete log or factor a number
unsigned int DiscreteLogWorkFactor(unsigned int bitlength);
unsigned int FactoringWorkFactor(unsigned int bitlength);

// ********************************************************

//! generator of prime numbers of special forms
class PrimeAndGenerator
{
public:
	PrimeAndGenerator() {}
	// generate a random prime p of the form 2*q+delta, where delta is 1 or -1 and q is also prime
	// Precondition: pbits > 5
	// warning: this is slow, because primes of this form are harder to find
	PrimeAndGenerator(signed int delta, RandomNumberGenerator &rng, unsigned int pbits)
		{Generate(delta, rng, pbits, pbits-1);}
	// generate a random prime p of the form 2*r*q+delta, where q is also prime
	// Precondition: qbits > 4 && pbits > qbits
	PrimeAndGenerator(signed int delta, RandomNumberGenerator &rng, unsigned int pbits, unsigned qbits)
		{Generate(delta, rng, pbits, qbits);}
	
	void Generate(signed int delta, RandomNumberGenerator &rng, unsigned int pbits, unsigned qbits);

	const Integer& Prime() const {return p;}
	const Integer& SubPrime() const {return q;}
	const Integer& Generator() const {return g;}

private:
	Integer p, q, g;
};

NAMESPACE_END

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本强好片久久久久久aaa| 五月天久久比比资源色| 综合色天天鬼久久鬼色| 亚洲国产视频一区二区| 精品亚洲aⅴ乱码一区二区三区| 蜜臀国产一区二区三区在线播放 | 麻豆一区二区99久久久久| 狠狠久久亚洲欧美| 91丨九色丨蝌蚪富婆spa| 色哟哟一区二区三区| 欧美成人精精品一区二区频| 中文字幕一区在线观看| 男男视频亚洲欧美| 成人av电影在线观看| 国产一区二区三区黄视频 | 国产日韩欧美不卡| 午夜影院久久久| 在线欧美日韩精品| 国产伦精品一区二区三区在线观看| 99精品欧美一区二区三区综合在线| 亚洲激情中文1区| 日本高清免费不卡视频| 亚洲高清视频在线| 日韩美女视频在线| 92精品国产成人观看免费| 一区二区三区在线视频观看| 91精品欧美综合在线观看最新| 亚洲色图欧美在线| 69久久夜色精品国产69蝌蚪网| 激情成人午夜视频| 久久久久青草大香线综合精品| 欧美日韩国产精品成人| 亚洲乱码日产精品bd| 色婷婷综合久久久久中文一区二区| 中文字幕亚洲一区二区va在线| 色8久久精品久久久久久蜜| 日本道在线观看一区二区| 国产精品情趣视频| 91在线观看成人| 国产无一区二区| 久久99国内精品| 欧美日韩在线电影| 香蕉久久夜色精品国产使用方法| 91视视频在线观看入口直接观看www | 亚洲精品一区二区三区蜜桃下载 | 欧美一区二区三区在线| 精品一区二区影视| 久久国产免费看| 亚洲人成在线观看一区二区| 中文字幕精品综合| 国产视频一区二区三区在线观看| 99国产精品久久久久久久久久| 国内精品久久久久影院色 | 欧美人妖巨大在线| 成人成人成人在线视频| 成人午夜视频在线观看| 国产精品一区二区黑丝| 国产成人精品免费| 国内精品免费**视频| 日韩二区在线观看| 美女视频免费一区| 成人av中文字幕| 欧美色国产精品| 国产精品蜜臀av| 亚洲小说春色综合另类电影| 91成人网在线| 欧美日本视频在线| 91精品国产综合久久久久久久| 日韩精品最新网址| 国产精品天干天干在线综合| 国产91精品一区二区麻豆亚洲| 樱桃视频在线观看一区| 日本一区二区成人| 97久久超碰国产精品| 婷婷久久综合九色综合绿巨人 | 欧美极品xxx| 欧美日韩精品三区| av激情成人网| 色噜噜狠狠色综合中国| 三级成人在线视频| 国产亚洲欧美一级| 日韩国产欧美在线播放| 欧美日本韩国一区二区三区视频| 亚洲精品福利视频网站| 国产一区二区美女诱惑| 欧美一级日韩免费不卡| 自拍av一区二区三区| 国产一区不卡视频| 国产亚洲精品7777| 欧美日韩电影在线播放| 欧美亚洲一区二区在线观看| 91精品国产高清一区二区三区| 亚洲高清免费视频| 亚洲色欲色欲www在线观看| 欧美成人性战久久| 51精品久久久久久久蜜臀| 色先锋久久av资源部| 大桥未久av一区二区三区中文| 精品亚洲成a人在线观看| 五月激情综合色| 亚洲伊人色欲综合网| 一区二区三区日韩欧美| 亚洲欧洲精品一区二区精品久久久 | 中文字幕一区二区在线播放| 久久综合九色综合97婷婷| 欧美一级片免费看| 91精品国产综合久久精品麻豆| 91免费观看视频在线| 99在线热播精品免费| 成人高清av在线| 懂色av中文一区二区三区| 国产成人啪免费观看软件| 国产精一品亚洲二区在线视频| 国产在线精品一区二区不卡了| 日韩一区精品字幕| 青青草国产精品亚洲专区无| 青青草一区二区三区| 蜜臀久久99精品久久久久久9| 人妖欧美一区二区| 蜜桃视频在线观看一区二区| 免费成人在线播放| 一本久道久久综合中文字幕| 91在线国产观看| 91搞黄在线观看| 欧美丰满嫩嫩电影| 精品欧美乱码久久久久久1区2区| 欧美一区二区在线看| 欧美一区二区三区在线看| 欧美电视剧免费观看| 国产日韩在线不卡| 亚洲视频在线一区二区| 夜夜操天天操亚洲| 人妖欧美一区二区| 国产精品77777| 91免费观看在线| 91精品一区二区三区久久久久久 | 7777精品伊人久久久大香线蕉超级流畅 | 精品日韩欧美在线| 欧美一级搡bbbb搡bbbb| 日韩欧美在线影院| 久久精品亚洲精品国产欧美kt∨| 欧美一级在线免费| 欧美精品日韩综合在线| 91精品国产综合久久久久久漫画| 91麻豆精品国产91久久久久久| 欧美伦理视频网站| 26uuu亚洲综合色| 亚洲一区视频在线观看视频| 一区二区三区成人| 国内不卡的二区三区中文字幕| 韩国av一区二区三区在线观看| www.亚洲精品| 日韩午夜电影在线观看| 国产精品超碰97尤物18| 亚洲v日本v欧美v久久精品| 男男视频亚洲欧美| 91伊人久久大香线蕉| 亚洲精品一区二区三区蜜桃下载 | 亚洲丝袜美腿综合| 亚洲一区二区三区四区的| 国产成人在线免费| 欧美性做爰猛烈叫床潮| 久久精品视频免费| 免费不卡在线观看| 91在线你懂得| 中文av一区二区| 欧美丝袜自拍制服另类| 99视频精品免费视频| 99久久婷婷国产综合精品电影| 国产精品99久久不卡二区| 欧美揉bbbbb揉bbbbb| 欧美激情中文不卡| 精品亚洲国产成人av制服丝袜 | 中日韩av电影| 蜜桃久久久久久久| 51精品秘密在线观看| 亚洲乱码精品一二三四区日韩在线| 久久99热这里只有精品| 欧洲精品在线观看| 一区二区三区资源| 一本色道久久综合亚洲aⅴ蜜桃| 亚洲第一久久影院| 欧美日韩一区二区在线视频| 亚洲国产cao| 精品美女被调教视频大全网站| 亚洲成人av一区二区三区| 色香色香欲天天天影视综合网 | 欧美人与禽zozo性伦| 中文字幕视频一区| 在线免费观看不卡av| 亚洲狠狠爱一区二区三区| 欧美主播一区二区三区美女| 亚洲小说欧美激情另类| 91精品国产入口在线| 琪琪久久久久日韩精品| 午夜视频在线观看一区二区 | 波多野结衣中文字幕一区| 日韩精品福利网| 最新中文字幕一区二区三区 | 日韩在线a电影|