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

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

?? algebra.h

?? 應用非對稱密鑰系統RSA密碼系統進行數據簽名的代碼
?? H
字號:
#ifndef CRYPTOPP_ALGEBRA_H
#define CRYPTOPP_ALGEBRA_H

#include "config.h"

NAMESPACE_BEGIN(CryptoPP)

class Integer;

// "const Element&" returned by member functions are references
// to internal data members. Since each object may have only
// one such data member for holding results, the following code
// will produce incorrect results:
// abcd = group.Add(group.Add(a,b), group.Add(c,d));
// But this should be fine:
// abcd = group.Add(a, group.Add(b, group.Add(c,d));

//! Abstract Group
template <class T> class CRYPTOPP_NO_VTABLE AbstractGroup
{
public:
	typedef T Element;

	virtual ~AbstractGroup() {}

	virtual bool Equal(const Element &a, const Element &b) const =0;
	virtual const Element& Identity() const =0;
	virtual const Element& Add(const Element &a, const Element &b) const =0;
	virtual const Element& Inverse(const Element &a) const =0;
	virtual bool InversionIsFast() const {return false;}

	virtual const Element& Double(const Element &a) const;
	virtual const Element& Subtract(const Element &a, const Element &b) const;
	virtual Element& Accumulate(Element &a, const Element &b) const;
	virtual Element& Reduce(Element &a, const Element &b) const;

	virtual Element ScalarMultiply(const Element &a, const Integer &e) const;
	virtual Element CascadeScalarMultiply(const Element &x, const Integer &e1, const Element &y, const Integer &e2) const;

	virtual void SimultaneousMultiply(Element *results, const Element &base, const Integer *exponents, unsigned int exponentsCount) const;
};

//! Abstract Ring
template <class T> class CRYPTOPP_NO_VTABLE AbstractRing : public AbstractGroup<T>
{
public:
	typedef T Element;

	AbstractRing() {m_mg.m_pRing = this;}
	AbstractRing(const AbstractRing &source) {m_mg.m_pRing = this;}
	AbstractRing& operator=(const AbstractRing &source) {return *this;}

	virtual bool IsUnit(const Element &a) const =0;
	virtual const Element& MultiplicativeIdentity() const =0;
	virtual const Element& Multiply(const Element &a, const Element &b) const =0;
	virtual const Element& MultiplicativeInverse(const Element &a) const =0;

	virtual const Element& Square(const Element &a) const;
	virtual const Element& Divide(const Element &a, const Element &b) const;

	virtual Element Exponentiate(const Element &a, const Integer &e) const;
	virtual Element CascadeExponentiate(const Element &x, const Integer &e1, const Element &y, const Integer &e2) const;

	virtual void SimultaneousExponentiate(Element *results, const Element &base, const Integer *exponents, unsigned int exponentsCount) const;

	virtual const AbstractGroup<T>& MultiplicativeGroup() const
		{return m_mg;}

private:
	class MultiplicativeGroupT : public AbstractGroup<T>
	{
	public:
		const AbstractRing<T>& GetRing() const
			{return *m_pRing;}

		bool Equal(const Element &a, const Element &b) const
			{return GetRing().Equal(a, b);}

		const Element& Identity() const
			{return GetRing().MultiplicativeIdentity();}

		const Element& Add(const Element &a, const Element &b) const
			{return GetRing().Multiply(a, b);}

		Element& Accumulate(Element &a, const Element &b) const
			{return a = GetRing().Multiply(a, b);}

		const Element& Inverse(const Element &a) const
			{return GetRing().MultiplicativeInverse(a);}

		const Element& Subtract(const Element &a, const Element &b) const
			{return GetRing().Divide(a, b);}

		Element& Reduce(Element &a, const Element &b) const
			{return a = GetRing().Divide(a, b);}

		const Element& Double(const Element &a) const
			{return GetRing().Square(a);}

		Element ScalarMultiply(const Element &a, const Integer &e) const
			{return GetRing().Exponentiate(a, e);}

		Element CascadeScalarMultiply(const Element &x, const Integer &e1, const Element &y, const Integer &e2) const
			{return GetRing().CascadeExponentiate(x, e1, y, e2);}

		void SimultaneousMultiply(Element *results, const Element &base, const Integer *exponents, unsigned int exponentsCount) const
			{GetRing().SimultaneousExponentiate(results, base, exponents, exponentsCount);}

		const AbstractRing<T> *m_pRing;
	};

	MultiplicativeGroupT m_mg;
};

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

//! Base and Exponent
template <class T, class E = Integer>
struct BaseAndExponent
{
public:
	BaseAndExponent() {}
	BaseAndExponent(const T &base, const E &exponent) : base(base), exponent(exponent) {}
	bool operator<(const BaseAndExponent<T, E> &rhs) const {return exponent < rhs.exponent;}
	T base;
	E exponent;
};

// VC60 workaround: incomplete member template support
template <class Element, class Iterator>
	Element GeneralCascadeMultiplication(const AbstractGroup<Element> &group, Iterator begin, Iterator end);
template <class Element, class Iterator>
	Element GeneralCascadeExponentiation(const AbstractRing<Element> &ring, Iterator begin, Iterator end);

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

//! Abstract Euclidean Domain
template <class T> class CRYPTOPP_NO_VTABLE AbstractEuclideanDomain : public AbstractRing<T>
{
public:
	typedef T Element;

	virtual void DivisionAlgorithm(Element &r, Element &q, const Element &a, const Element &d) const =0;

	virtual const Element& Mod(const Element &a, const Element &b) const =0;
	virtual const Element& Gcd(const Element &a, const Element &b) const;

protected:
	mutable Element result;
};

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

//! EuclideanDomainOf
template <class T> class EuclideanDomainOf : public AbstractEuclideanDomain<T>
{
public:
	typedef T Element;

	EuclideanDomainOf() {}

	bool Equal(const Element &a, const Element &b) const
		{return a==b;}

	const Element& Identity() const
		{return Element::Zero();}

	const Element& Add(const Element &a, const Element &b) const
		{return result = a+b;}

	Element& Accumulate(Element &a, const Element &b) const
		{return a+=b;}

	const Element& Inverse(const Element &a) const
		{return result = -a;}

	const Element& Subtract(const Element &a, const Element &b) const
		{return result = a-b;}

	Element& Reduce(Element &a, const Element &b) const
		{return a-=b;}

	const Element& Double(const Element &a) const
		{return result = a.Doubled();}

	const Element& MultiplicativeIdentity() const
		{return Element::One();}

	const Element& Multiply(const Element &a, const Element &b) const
		{return result = a*b;}

	const Element& Square(const Element &a) const
		{return result = a.Squared();}

	bool IsUnit(const Element &a) const
		{return a.IsUnit();}

	const Element& MultiplicativeInverse(const Element &a) const
		{return result = a.MultiplicativeInverse();}

	const Element& Divide(const Element &a, const Element &b) const
		{return result = a/b;}

	const Element& Mod(const Element &a, const Element &b) const
		{return result = a%b;}

	void DivisionAlgorithm(Element &r, Element &q, const Element &a, const Element &d) const
		{Element::Divide(r, q, a, d);}

	bool operator==(const EuclideanDomainOf<T> &rhs) const
		{return true;}

private:
	mutable Element result;
};

//! Quotient Ring
template <class T> class QuotientRing : public AbstractRing<typename T::Element>
{
public:
	typedef T EuclideanDomain;
	typedef typename T::Element Element;

	QuotientRing(const EuclideanDomain &domain, const Element &modulus)
		: m_domain(domain), m_modulus(modulus) {}

	const EuclideanDomain & GetDomain() const
		{return m_domain;}

	const Element& GetModulus() const
		{return m_modulus;}

	bool Equal(const Element &a, const Element &b) const
		{return m_domain.Equal(m_domain.Mod(m_domain.Subtract(a, b), m_modulus), m_domain.Identity());}

	const Element& Identity() const
		{return m_domain.Identity();}

	const Element& Add(const Element &a, const Element &b) const
		{return m_domain.Add(a, b);}

	Element& Accumulate(Element &a, const Element &b) const
		{return m_domain.Accumulate(a, b);}

	const Element& Inverse(const Element &a) const
		{return m_domain.Inverse(a);}

	const Element& Subtract(const Element &a, const Element &b) const
		{return m_domain.Subtract(a, b);}

	Element& Reduce(Element &a, const Element &b) const
		{return m_domain.Reduce(a, b);}

	const Element& Double(const Element &a) const
		{return m_domain.Double(a);}

	bool IsUnit(const Element &a) const
		{return m_domain.IsUnit(m_domain.Gcd(a, m_modulus));}

	const Element& MultiplicativeIdentity() const
		{return m_domain.MultiplicativeIdentity();}

	const Element& Multiply(const Element &a, const Element &b) const
		{return m_domain.Mod(m_domain.Multiply(a, b), m_modulus);}

	const Element& Square(const Element &a) const
		{return m_domain.Mod(m_domain.Square(a), m_modulus);}

	const Element& MultiplicativeInverse(const Element &a) const;

	bool operator==(const QuotientRing<T> &rhs) const
		{return m_domain == rhs.m_domain && m_modulus == rhs.m_modulus;}

protected:
	EuclideanDomain m_domain;
	Element m_modulus;
};

NAMESPACE_END

#ifdef CRYPTOPP_MANUALLY_INSTANTIATE_TEMPLATES
#include "algebra.cpp"
#endif

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品网站导航| 日产欧产美韩系列久久99| 亚洲国产精品视频| 国产精品夜夜嗨| 在线成人小视频| 亚洲激情校园春色| 处破女av一区二区| 欧美成人三级在线| 婷婷中文字幕一区三区| 不卡一二三区首页| 国产亚洲精品超碰| 免费成人你懂的| 在线精品国精品国产尤物884a| 国产日产欧美精品一区二区三区| 亚洲风情在线资源站| 一本色道久久综合狠狠躁的推荐| 国产免费久久精品| 国产成人综合视频| 日韩欧美一级在线播放| 日韩精品乱码av一区二区| 在线视频欧美精品| 一区二区三区不卡视频| 99re亚洲国产精品| 中文字幕亚洲电影| 99免费精品在线观看| 中文字幕中文乱码欧美一区二区| 国产成人综合亚洲91猫咪| 久久日韩精品一区二区五区| 久久精品国产在热久久| 欧美一区二区三区四区在线观看| 亚洲国产日产av| 欧美久久久久久蜜桃| 日本在线不卡一区| 精品久久久久久久久久久久久久久久久 | 国产精品亚洲第一区在线暖暖韩国 | 欧美大片免费久久精品三p| 婷婷综合久久一区二区三区| 欧美性大战久久| 午夜久久久久久| 91精品在线免费| 精品中文字幕一区二区小辣椒| 欧美成人video| 国产精品一区二区视频| 国产精品色哟哟| 一本久久a久久精品亚洲| 亚洲一区二区三区免费视频| 欧美精品日韩一本| 久久精品国产一区二区三区免费看| 精品日韩欧美在线| 懂色av一区二区三区蜜臀| 中文字幕综合网| 欧美久久久一区| 国产福利精品一区二区| 亚洲激情男女视频| 欧美一区二区三区视频在线观看 | 精品粉嫩超白一线天av| 国产麻豆成人精品| 亚洲精品国久久99热| 91精品久久久久久蜜臀| 国产成人亚洲精品青草天美 | 久久久久久久精| 色欧美乱欧美15图片| 日韩国产在线一| 国产精品久久久久久亚洲伦| 欧美影片第一页| 国产又黄又大久久| 亚洲综合一区二区三区| 欧美一区二区观看视频| 97精品久久久久中文字幕| 日本午夜精品视频在线观看| 国产精品国产三级国产普通话三级| 欧美日韩美少妇| 成人国产一区二区三区精品| 亚洲电影第三页| 国产精品第一页第二页第三页| 欧美久久久久中文字幕| 不卡的电视剧免费网站有什么| 性感美女久久精品| 中文字幕在线不卡一区二区三区| 欧美一级艳片视频免费观看| 91日韩在线专区| 韩国欧美一区二区| 天天影视网天天综合色在线播放| 中文字幕精品一区| 日韩一区国产二区欧美三区| 色先锋资源久久综合| 国产99久久久国产精品潘金网站| 婷婷开心久久网| 樱花草国产18久久久久| 国产精品日日摸夜夜摸av| 亚洲精品一区二区三区香蕉| 欧美视频一区二区| 色婷婷国产精品| 91丨九色丨尤物| 成人的网站免费观看| 国产精品原创巨作av| 免播放器亚洲一区| 奇米一区二区三区av| 五月激情丁香一区二区三区| 亚洲免费观看在线视频| 中文字幕一区二区在线观看| 国产欧美视频一区二区三区| 精品国产一区二区三区不卡 | 日本成人中文字幕| 亚洲午夜激情av| 一区二区不卡在线视频 午夜欧美不卡在| 中文字幕精品在线不卡| 国产日韩欧美精品电影三级在线 | 国产成人精品免费看| 久久97超碰国产精品超碰| 蜜桃视频在线一区| 日本在线不卡视频| 青娱乐精品视频| 奇米四色…亚洲| 久久疯狂做爰流白浆xx| 久久精品国产网站| 国产综合色在线视频区| 激情六月婷婷久久| 国产精品一区久久久久| 丁香桃色午夜亚洲一区二区三区| 国产91在线|亚洲| 懂色av中文字幕一区二区三区| hitomi一区二区三区精品| 色综合久久天天| 欧洲在线/亚洲| 在线综合+亚洲+欧美中文字幕| 91精品国产一区二区三区| 欧美一区二区日韩| 久久久国际精品| 亚洲美女视频一区| 亚洲一线二线三线视频| 日本成人中文字幕在线视频| 国产一区二区三区在线观看免费视频 | 精品成人a区在线观看| 久久一二三国产| 国产精品激情偷乱一区二区∴| 一区二区三区精品视频| 亚洲va欧美va人人爽| 久久99国产精品久久99果冻传媒 | 国产精品一卡二| 不卡高清视频专区| 精品视频色一区| 精品电影一区二区| 亚洲精品视频在线看| 青椒成人免费视频| 99精品国产热久久91蜜凸| 欧美另类久久久品| 国产亚洲va综合人人澡精品 | 中文在线资源观看网站视频免费不卡 | 老司机午夜精品99久久| 成人av影院在线| 91精品婷婷国产综合久久 | 亚洲精选一二三| 免费成人在线播放| 91在线观看成人| 日韩久久精品一区| 一区二区三区在线播放| 国产精品99久久久久久宅男| 欧美中文字幕亚洲一区二区va在线| 日韩精品一区二区三区老鸭窝| 亚洲日本一区二区| 精品在线观看免费| 在线免费观看日韩欧美| 国产午夜一区二区三区| 肉色丝袜一区二区| 99re热这里只有精品免费视频| 欧美mv和日韩mv国产网站| 亚洲综合色在线| 成人免费看片app下载| 欧美精品一区视频| 美女免费视频一区二区| 色乱码一区二区三区88| 久久嫩草精品久久久精品一| 日韩精品亚洲一区二区三区免费| av一二三不卡影片| 国产亚洲欧美日韩在线一区| 奇米影视7777精品一区二区| 在线观看亚洲一区| 成人免费一区二区三区在线观看| 国产资源在线一区| 欧美电视剧免费全集观看| 亚洲地区一二三色| 91网上在线视频| 亚洲视频一区在线观看| 大桥未久av一区二区三区中文| 久久久三级国产网站| 韩国av一区二区| 欧美电影免费观看完整版| 蜜桃av一区二区三区电影| 欧美日韩小视频| 日韩影院免费视频| 欧美电影一区二区三区| 天堂va蜜桃一区二区三区| 欧美丝袜丝nylons| 亚洲国产日产av| 欧美一区二区视频免费观看| 日本欧美一区二区三区乱码| 欧美一二三区在线| 国产揄拍国内精品对白| 国产亚洲一区二区三区|