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

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

?? rr.h

?? 大數運算類
?? H
?? 第 1 頁 / 共 2 頁
字號:
#ifndef NTL_RR__H
#define NTL_RR__H

#include <NTL/ZZ.h>
#include <NTL/xdouble.h>
#include <NTL/quad_float.h>

NTL_OPEN_NNS


class RR {

public:

ZZ x;
long e;

RR() {  e = 0; }

inline RR(INIT_VAL_TYPE, const ZZ& a);
inline RR(INIT_VAL_TYPE, int a);
inline RR(INIT_VAL_TYPE, long a);
inline RR(INIT_VAL_TYPE, unsigned int a);
inline RR(INIT_VAL_TYPE, unsigned long a);
inline RR(INIT_VAL_TYPE, float a);
inline RR(INIT_VAL_TYPE, double a);
inline RR(INIT_VAL_TYPE, const xdouble& a);
inline RR(INIT_VAL_TYPE, const quad_float& a);
inline RR(INIT_VAL_TYPE, const char *a);  // read from string
inline RR(INIT_VAL_TYPE, const RR& a);


inline RR& operator=(double a);

RR(RR& z, INIT_TRANS_TYPE) : x(z.x, INIT_TRANS), e(z.e) { } 





~RR() { }

const ZZ& mantissa() const { return x; }
long exponent() const { return e; }

static long prec;
static void SetPrecision(long p);
static long precision() { return prec; }

static long oprec;
static void SetOutputPrecision(long p);
static long OutputPrecision() { return oprec; }

#ifdef NTL_TRANSITION
private:
RR& operator=(const RR&);
RR(const RR&);
#endif

};


long IsZero(const RR& a);
long IsOne(const RR& a);
long sign(const RR& a);
void clear(RR& z);
void set(RR& z);
void swap(RR& a, RR& b);

void add(RR& z, const RR& a, const RR& b);

void add(RR& z, const RR& a, double b);
inline void add(RR& z, double a, const RR& b) { add(z, b, a); }



void sub(RR& z, const RR& a, const RR& b);

void sub(RR& z, const RR& a, double b);
void sub(RR& z, double a, const RR& b);

void negate(RR& z, const RR& a);

void abs(RR& z, const RR& a);
inline RR abs(const RR& a)
   { RR z; abs(z, a); NTL_OPT_RETURN(RR, z); }
inline RR fabs(const RR& a)
   { RR z; abs(z, a); NTL_OPT_RETURN(RR, z); }

void mul(RR& z, const RR& a, const RR& b);

void mul(RR& z, const RR& a, double b);
inline void mul(RR& z, double a, const RR& b) { mul(z, b, a); }

void sqr(RR& z, const RR& a);
inline RR sqr(const RR& a)
   { RR z; sqr(z, a); NTL_OPT_RETURN(RR, z); }

void div(RR& z, const RR& a, const RR& b);

void div(RR& z, const RR& a, double b);
void div(RR& z, double a, const RR& b);

void inv(RR& z, const RR& a);
inline RR inv(const RR& a)
   { RR z; inv(z, a); NTL_OPT_RETURN(RR, z); }

// operator notation:

inline RR operator+(const RR& a, const RR& b)
   { RR x; add(x, a, b); NTL_OPT_RETURN(RR, x); }

inline RR operator+(const RR& a, double b)
   { RR x; add(x, a, b); NTL_OPT_RETURN(RR, x); }

inline RR operator+(double a, const RR& b)
   { RR x; add(x, a, b); NTL_OPT_RETURN(RR, x); }

inline RR& operator+=(RR& x, const RR& b)
   { add(x, x, b); return x; } 

inline RR& operator+=(RR& x, double b)
   { add(x, x, b); return x; } 



inline RR operator-(const RR& a, const RR& b)
   { RR x; sub(x, a, b); NTL_OPT_RETURN(RR, x); }

inline RR operator-(const RR& a, double b)
   { RR x; sub(x, a, b); NTL_OPT_RETURN(RR, x); }

inline RR operator-(double a, const RR& b)
   { RR x; sub(x, a, b); NTL_OPT_RETURN(RR, x); }

inline RR& operator-=(RR& x, const RR& b)
   { sub(x, x, b); return x; } 

inline RR& operator-=(RR& x, double b)
   { sub(x, x, b); return x; } 



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

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

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

inline RR& operator*=(RR& x, const RR& b)
   { mul(x, x, b); return x; } 

inline RR& operator*=(RR& x, double b)
   { mul(x, x, b); return x; } 


inline RR operator/(const RR& a, const RR& b)
   { RR x; div(x, a, b); NTL_OPT_RETURN(RR, x); }

inline RR operator/(const RR& a, double b)
   { RR x; div(x, a, b); NTL_OPT_RETURN(RR, x); }

inline RR operator/(double a, const RR& b)
   { RR x; div(x, a, b); NTL_OPT_RETURN(RR, x); }

inline RR& operator/=(RR& x, const RR& b)
   { div(x, x, b); return x; } 

inline RR& operator/=(RR& x, double b)
   { div(x, x, b); return x; } 


inline RR operator-(const RR& a)
   { RR x; negate(x, a); NTL_OPT_RETURN(RR, x); }


inline RR& operator++(RR& x) { add(x, x, 1); return x; }
inline void operator++(RR& x, int) { add(x, x, 1); }
inline RR& operator--(RR& x) { sub(x, x, 1); return x; }
inline void operator--(RR& x, int) { sub(x, x, 1); }



long compare(const RR& a, const RR& b);

long compare(const RR& a, double b);
inline long compare(double a, const RR& b) { return -compare(b, a); }


long operator==(const RR& a, const RR& b);
inline long operator!=(const RR& a, const RR& b) { return !(a == b); }
inline long operator<=(const RR& a, const RR& b) { return compare(a, b) <= 0; }
inline long operator>=(const RR& a, const RR& b) { return compare(a, b) >= 0; }
inline long operator <(const RR& a, const RR& b) { return compare(a, b)  < 0; }
inline long operator >(const RR& a, const RR& b) { return compare(a, b)  > 0; }

long operator==(const RR& a, double b);
inline long operator!=(const RR& a, double b) { return !(a == b); }
inline long operator<=(const RR& a, double b) { return compare(a, b) <= 0; }
inline long operator>=(const RR& a, double b) { return compare(a, b) >= 0; }
inline long operator <(const RR& a, double b) { return compare(a, b)  < 0; }
inline long operator >(const RR& a, double b) { return compare(a, b)  > 0; }

inline long operator==(double a, const RR& b) { return (b == a); }
inline long operator!=(double a, const RR& b) { return !(a == b); }
inline long operator<=(double a, const RR& b) { return compare(a, b) <= 0; }
inline long operator>=(double a, const RR& b) { return compare(a, b) >= 0; }
inline long operator <(double a, const RR& b) { return compare(a, b)  < 0; }
inline long operator >(double a, const RR& b) { return compare(a, b)  > 0; }

void ceil(RR& z, const RR& a);
inline RR ceil(const RR& a)
   { RR z; ceil(z, a); NTL_OPT_RETURN(RR, z); }

void floor(RR& z, const RR& a);
inline RR floor(const RR& a)
   { RR z; floor(z, a); NTL_OPT_RETURN(RR, z); }

void trunc(RR& z, const RR& a);
inline RR trunc(const RR& a)
   { RR z; trunc(z, a); NTL_OPT_RETURN(RR, z); }

void round(RR& z, const RR& a);
inline RR round(const RR& a)
   { RR z; round(z, a); NTL_OPT_RETURN(RR, z); }

void RoundToPrecision(RR& z, const RR& a, long p);
inline RR RoundToPrecision(const RR& a, long p)
   { RR z; RoundToPrecision(z, a, p); NTL_OPT_RETURN(RR, z); }


// routines with a precision parameter

void ConvPrec(RR& z, const RR& a, long p);
inline RR ConvPrec(const RR& a, long p)
   { RR z; ConvPrec(z, a, p); NTL_OPT_RETURN(RR, z); }

void AddPrec(RR& z, const RR& a, const RR& b, long p);
inline RR AddPrec(const RR& a, const RR& b, long p)
   { RR z; AddPrec(z, a, b, p); NTL_OPT_RETURN(RR, z); }

void SubPrec(RR& z, const RR& a, const RR& b, long p);
inline RR SubPrec(const RR& a, const RR& b, long p)
   { RR z; SubPrec(z, a, b, p); NTL_OPT_RETURN(RR, z); }

void NegatePrec(RR& z, const RR& a, long p);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一区二| 91精品国产入口在线| 欧美成人高清电影在线| 亚洲精品写真福利| 国产传媒欧美日韩成人| 91精品综合久久久久久| 亚洲免费观看视频| 成人三级伦理片| 精品美女一区二区| 视频一区欧美精品| 在线中文字幕不卡| 国产精品国产三级国产aⅴ入口| 免费视频一区二区| 欧美日韩dvd在线观看| 亚洲视频综合在线| 国产精品一区二区在线观看网站| 欧美一级久久久| 亚洲成人tv网| 在线免费视频一区二区| 亚洲色图视频免费播放| 懂色av中文一区二区三区| 欧美v日韩v国产v| 日韩国产欧美三级| 欧美日韩国产一区| 亚洲午夜久久久久中文字幕久| 99免费精品在线| 国产精品三级视频| 国产91在线看| 中文天堂在线一区| 国产成人精品免费在线| 国产午夜亚洲精品午夜鲁丝片| 久久成人精品无人区| 欧美一区二区私人影院日本| 天天av天天翘天天综合网色鬼国产| 91成人网在线| 亚洲午夜久久久久久久久电影网| 色哟哟国产精品| 亚洲免费观看高清完整版在线| 91在线视频观看| 亚洲欧美国产毛片在线| 一道本成人在线| 91麻豆蜜桃一区二区三区| 国产精品蜜臀在线观看| 成人性生交大片免费| 国产精品蜜臀在线观看| 91一区二区在线观看| 亚洲美女区一区| 欧美在线观看18| 亚洲va天堂va国产va久| 欧美日韩国产综合一区二区| 日韩国产在线一| 日韩欧美亚洲国产精品字幕久久久| 久久福利视频一区二区| 久久一区二区视频| 国产成人自拍高清视频在线免费播放| 国产亚洲制服色| 波多野结衣精品在线| 成人免费小视频| 欧美视频一区二区三区| 婷婷六月综合网| 精品精品国产高清a毛片牛牛| 成人国产免费视频| 久久久亚洲欧洲日产国码αv| 亚洲综合图片区| 日本成人在线网站| 欧美手机在线视频| 国产亚洲欧美色| 欧美aaa在线| 久久精品一区四区| 99国内精品久久| 亚洲成人av电影| 欧美va亚洲va在线观看蝴蝶网| 国产精品一级在线| 一区2区3区在线看| 欧美一区三区二区| 国产精品18久久久久久久久 | 免费精品视频最新在线| 久久综合九色综合97婷婷| 成人高清在线视频| 午夜欧美2019年伦理| 久久夜色精品国产欧美乱极品| 成人激情黄色小说| 日韩中文字幕不卡| 亚洲国产经典视频| 精品视频色一区| 国产福利一区在线| 亚洲r级在线视频| 精品国产免费久久| 色天使色偷偷av一区二区| 婷婷国产在线综合| 国产片一区二区| 欧美三级日韩三级国产三级| 国产一区二区不卡| 亚洲午夜久久久久久久久电影院| 26uuu国产在线精品一区二区| 92国产精品观看| 精品一二三四在线| 亚洲最大成人网4388xx| 久久综合av免费| 亚洲乱码精品一二三四区日韩在线| 91精品国产高清一区二区三区| 国产成人av电影在线播放| 亚洲激情一二三区| 久久久久久久久久电影| 欧美午夜精品久久久久久超碰 | 五月天丁香久久| 欧美韩日一区二区三区四区| 在线区一区二视频| 成熟亚洲日本毛茸茸凸凹| 婷婷国产v国产偷v亚洲高清| 国产精品三级电影| 欧美本精品男人aⅴ天堂| 欧美视频日韩视频| 成人国产精品免费| 国产一区在线不卡| 强制捆绑调教一区二区| 亚洲精品videosex极品| 国产精品无码永久免费888| 91精品国产一区二区| 日本高清不卡一区| 波多野结衣精品在线| 国产在线精品免费| 日韩电影免费在线| 亚洲一区二区三区视频在线播放| 国产人伦精品一区二区| 精品剧情在线观看| 日韩欧美在线一区二区三区| 欧美在线观看一二区| jlzzjlzz欧美大全| 国产激情偷乱视频一区二区三区 | 国产日韩综合av| 日韩美女一区二区三区四区| 欧美日本韩国一区二区三区视频| aaa欧美日韩| 成人激情免费电影网址| 国产精品99久久久久久久女警| 久久99久久99| 奇米精品一区二区三区四区| 亚洲大型综合色站| 亚洲最新视频在线观看| 尤物在线观看一区| 亚洲女与黑人做爰| 亚洲天堂久久久久久久| 国产精品卡一卡二卡三| 国产精品天美传媒| 国产欧美日韩另类一区| 国产偷国产偷亚洲高清人白洁| 精品国产乱子伦一区| 日韩欧美一区二区视频| 91精品国产免费久久综合| 91精品国产91久久久久久一区二区| 欧美色视频在线| 欧美日韩卡一卡二| 欧美日韩五月天| 欧美精品在欧美一区二区少妇| 欧美色图12p| 欧美电影在哪看比较好| 91精品国产欧美一区二区18| 欧美精品一二三区| 欧美日韩精品高清| 日韩不卡一区二区| 麻豆精品视频在线| 国内精品久久久久影院色| 狠狠狠色丁香婷婷综合激情 | 日本午夜精品一区二区三区电影| 午夜精品一区二区三区三上悠亚| 五月婷婷综合激情| 麻豆精品视频在线| 国产高清精品网站| 成人黄色在线网站| 91国偷自产一区二区三区成为亚洲经典 | 亚洲午夜三级在线| 亚洲午夜在线观看视频在线| 亚洲成人综合视频| 日韩av中文字幕一区二区三区| 亚洲成人tv网| 蜜桃av一区二区| 国产麻豆午夜三级精品| 成人一区在线看| 91福利区一区二区三区| 欧美丰满一区二区免费视频| 精品国精品国产| 国产精品久久综合| 亚洲图片有声小说| 麻豆国产欧美日韩综合精品二区 | 日韩精品欧美成人高清一区二区| 免费成人在线观看| 国产一区美女在线| 成人av资源站| 欧美日韩国产美| 欧美成人一区二区三区| 国产精品美女一区二区在线观看| 玉米视频成人免费看| 免费成人美女在线观看.| 国产精品66部| 欧美色网站导航| 久久综合国产精品| 亚洲美女视频在线观看| 麻豆国产精品一区二区三区 | 欧美aa在线视频|