分数Frac类
用于優化浮點數除法的精度問題,可以直接扔map里用
白嫖黨大勝利
template <typename VAL> class Frac { public:VAL num,den;Frac(){}Frac(const VAL& x, const VAL& y = 1){den=__gcd(x,y);num=x/den,den=y/den;if(den<0) num=-num,den=-den;}bool operator <(const Frac& rhs) const {return num*rhs.den<rhs.num*den;}bool operator==(const Frac& rhs) const {return num==rhs.num && den==rhs.den;}Frac operator +(const Frac& rhs) const {return Frac(num*rhs.den+den*rhs.num,den*rhs.den);}Frac operator -(const Frac& rhs) const {return Frac(num*rhs.den-den*rhs.num,den*rhs.den);}Frac operator *(const Frac& rhs) const {return Frac(num*rhs.num,den*rhs.den);}Frac operator /(const Frac& rhs) const {return Frac(num*rhs.den,den*rhs.num);}Frac operator -() const {return Frac(-num,den);}Frac& operator +=(const Frac& rhs){return *this=*this+rhs;}Frac& operator -=(const Frac& rhs){return *this=*this-rhs;}Frac& operator *=(const Frac& rhs){return *this=*this*rhs;}Frac& operator /=(const Frac& rhs){return *this=*this/rhs;} }; using frac = Frac<LL>; 超強干貨來襲 云風專訪:近40年碼齡,通宵達旦的技術人生總結
- 上一篇: 2021牛客多校4 - Tree Xor
- 下一篇: 洛谷 - P4173 残缺的字符串(多项