-
Notifications
You must be signed in to change notification settings - Fork 26
/
Copy pathbigint.hpp
137 lines (111 loc) · 4.02 KB
/
bigint.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
/**
* Boost Software License - Version 1.0 - August 17th, 2003
* Permission is hereby granted, free of charge, to any person
* or organization obtaining a copy of the software and
* accompanying documentation covered by this license
* (the "Software") to use, reproduce, display, distribute,
* execute, and transmit the Software, and to prepare derivative
* works of the Software, and to permit third-parties to whom the
* Software is furnished to do so, all subject to the following:
*
* The copyright notices in the Software and this entire statement,
* including the above license grant, this restriction and the following
* disclaimer, must be included in all copies of the Software, in whole or
* in part, and all derivative works of the Software, unless such copies
* or derivative works are solely in the form of machine-executable
* object code generated by a source language processor.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND
* NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR ANYONE
* DISTRIBUTING THE SOFTWARE BE LIABLE FOR ANY DAMAGES OR OTHER LIABILITY,
* WHETHER IN CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*
*/
#ifndef BIG_INT_HPP
#define BIG_INT_HPP
#include <iostream>
#include <string>
#include <vector>
#include <complex>
namespace libbig
{
// constants used with the bool largeInt::sign attribute
// this->sign = POSITIVE; instead of this->sign = true;
constexpr bool POSITIVE = true;
constexpr bool NEGATIVE = false;
const double PI = 2*acos(0.0);
typedef std::vector<std::complex<double>> complexCoeffs;
class largeInt
{
private:
bool sign;
std::string number;
public:
largeInt();
explicit largeInt(int);
explicit largeInt(long long int);
explicit largeInt(const std::string&);
largeInt operator+(const largeInt&);
largeInt operator+(int);
largeInt operator+(int64_t);
largeInt operator-(const largeInt&);
largeInt operator-(int);
largeInt operator-(int64_t);
largeInt operator*(const largeInt&);
largeInt operator*(int);
largeInt operator*(int64_t);
largeInt operator/(const largeInt&);
largeInt operator/(int);
largeInt operator/(int64_t);
largeInt operator%(const largeInt&);
largeInt operator%(int);
largeInt operator%(int64_t);
largeInt &operator+=(const largeInt&);
largeInt &operator+=(int);
largeInt &operator+=(int64_t);
largeInt &operator-=(const largeInt&);
largeInt &operator-=(int);
largeInt &operator-=(int64_t);
largeInt &operator*=(const largeInt&);
largeInt &operator*=(int);
largeInt &operator*=(int64_t);
largeInt &operator/=(const largeInt&);
largeInt &operator/=(int);
largeInt &operator/=(int64_t);
largeInt operator%=(const largeInt&);
largeInt operator%=(int);
largeInt operator%=(int64_t);
// PREFIX OPERATORS
// POSTFIX OPERATORS
largeInt &operator=(const largeInt &);
largeInt &operator=(int);
largeInt &operator=(int64_t);
bool operator==(const largeInt &);
bool operator==(int);
bool operator==(int64_t);
bool operator!=(const largeInt&);
bool operator!=(int);
bool operator!=(int64_t);
bool operator<(const largeInt&);
bool operator<(int);
bool operator<(int64_t);
bool operator>(const largeInt&);
bool operator>(int);
bool operator>(int64_t);
bool operator<=(const largeInt&);
bool operator<=(int);
bool operator<=(int64_t);
bool operator>=(const largeInt&);
bool operator>=(int);
bool operator>=(int64_t);
friend std::istream &operator>>(std::istream &, largeInt &);
friend std::ostream &operator<<(std::ostream &, const largeInt &);
};
// HELPERS
int char_int_converter(const char&);
complexCoeffs fast_fourier_transform(const bool is_IDFT, const complexCoeffs);
} // namespace libbig
#endif