123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 |
- #ifndef RATIONNAL_HPP
- #define RATIONNAL_HPP
- #include <iostream>
- #include <cstdint>
- #include <iostream>
- #include "config.hpp"
- using namespace std;
- //*************
- //* Rationnal *
- //*************
- //! Class for representing rationnals.
- class Rationnal{
- private:
- //! Numerator
- Int num;
- //! Denominator
- Int den;
- //! Normalise th fraction
- void normalize();
- public:
- //! Construct the null rationnal
- Rationnal();
-
- //! Construct the rationnal n
- //! \param n integer
- Rationnal(Int n);
- //! Construct the rationnal n/d
- //! \param n numerator integer
- //! \param d denominator integer
- Rationnal(Int n,Int d);
- //! Copy constructor
- //! \param r rationnal to copy
- Rationnal(const Rationnal& r);
- //! Copy operator
- //! \param r rationnal to copy
- Rationnal& operator=(const Rationnal& r);
- //! Numerator accessor
- Int numerator() const;
- //! Denominator accessor
- Int denominator() const;
- //! Return an approximation of the rationnal
- explicit operator Reel() const;
- //! Addition operators
- Rationnal operator+(const Rationnal& r) const;
- Rationnal operator+(Int n) const;
- friend Rationnal operator+(Int n,const Rationnal& r);
- //! Substration operators
- Rationnal operator-(const Rationnal& r) const;
- Rationnal operator-(Int n) const;
- friend Rationnal operator-(Int n,const Rationnal& r);
- //! Multiplication operators
- Rationnal operator*(const Rationnal& r) const;
- Rationnal operator*(Int n) const;
- friend Rationnal operator*(Int n,const Rationnal& r);
- //! Division operators
- Rationnal operator/(const Rationnal& r) const;
- Rationnal operator/(Int n) const;
- friend Rationnal operator/(Int n,const Rationnal& r);
- };
- //-----------------
- // Other functions
- //-----------------
- ostream& operator<<(ostream& os,const Rationnal& r);
- Int gcd(Int a,Int b);
- //********************
- //* Inline functions *
- //********************
- inline
- Rationnal::Rationnal():num(0),den(1){
- }
- inline
- Rationnal::Rationnal(Int n):num(n),den(1){
- }
- inline
- Rationnal::Rationnal(Int n,Int d):num(n),den(d){
- normalize();
- }
- inline
- Rationnal::Rationnal(const Rationnal& r):num(r.num),den(r.den){
- }
- inline Rationnal&
- Rationnal::operator=(const Rationnal& r){
- num=r.num;
- den=r.den;
- return *this;
- }
-
- inline Int
- Rationnal::numerator() const{
- return num;
- }
- inline Int
- Rationnal::denominator() const{
- return den;
- }
- inline
- Rationnal::operator Reel() const{
- Reel n=num;
- Reel d=den;
- return n/d;
- }
- inline void
- Rationnal::normalize(){
- Int d=gcd((num<0)?-num:num,den);
- num/=d;
- den/=d;
- }
- inline Rationnal
- Rationnal::operator+(const Rationnal& r) const{
- return Rationnal(num*r.den+r.num*den,den*r.den);
- }
- inline Rationnal
- Rationnal::operator+(Int n) const{
- return Rationnal(num+n*den,den);
- }
- inline Rationnal
- Rationnal::operator-(const Rationnal& r) const{
- return Rationnal(num*r.den-r.num*den,den*r.den);
- }
- inline Rationnal
- Rationnal::operator-(Int n) const{
- return Rationnal(num-n*den,den);
- }
- inline Rationnal
- Rationnal::operator*(const Rationnal& r) const{
- return Rationnal(num*r.num,den*r.den);
- }
- inline Rationnal
- Rationnal::operator*(Int n) const{
- return Rationnal(num*n,den);
- }
- inline Rationnal
- Rationnal::operator/(const Rationnal& r) const{
- Int s=(r.num<0)?-1:1;
- return Rationnal(s*num*r.den,s*den*r.num);
- }
- inline Rationnal
- Rationnal::operator/(Int n) const{
- Int s=(n<0)?-1:1;
- return Rationnal(s*num,s*den*n);
- }
- inline Rationnal
- operator+(Int n,const Rationnal& r){
- return Rationnal(n*r.den+r.num,r.den);
- }
- inline Rationnal
- operator-(Int n,const Rationnal& r){
- return Rationnal(-n*r.den+r.num,r.den);
- }
- inline Rationnal
- operator*(Int n,const Rationnal& r){
- return Rationnal(n*r.num,r.den);
- }
- inline Rationnal
- operator/(Int n,const Rationnal& r){
- Int s=(n<0)?-1:1;
- return Rationnal(s*r.num,s*r.den*n);
- }
- #endif
|