Я создал класс MegaInt, который мог бы обрабатывать очень большие числа, и перегружал несколько операторов.К сожалению, я застрял, и мой код просто падает.
Каждый объект MegaInt имеет значение вектора и знак bool.Каждая позиция числа помещается в вектор (т. Е. 4325 является векторным значением = {5,2,3,4}), и его знак (+ или -) равен 1 или 0.
вот немногокода ...
#include <vector>
#include <string>
using namespace std;
class MegaInt{
friend class main;
private:
vector<int> value;
bool sign; //true is pos, false is neg
public:
MegaInt(vector <int> x, bool y);
MegaInt(string s);
MegaInt(const MegaInt& m);
MegaInt & operator*=(const MegaInt &rhs);
#include <iostream>
using namespace std;
#include "MegaInt.h"
#include <math.h>
MegaInt::MegaInt(string s){
int pos = s.length()-1;
while (pos >= 0){
if(pos == 0 && s[pos] == '-'){
sign = false;
break;
}
else if (pos == 0 && s[pos] == '+'){
sign = true;
break;
}
else{
sign = true;
}
if(s[pos] >= 48 && s[pos] <= 57)
value.push_back(s[pos]-48);
else{
value.clear();
break;
}
pos --;
}
chopoffleadingOs();
}
MegaInt::MegaInt(const MegaInt& m){
value = m.value;
sign = m.sign;
}
MegaInt operator*(const MegaInt& x, const MegaInt& y){
int multi = 0;
int temp;
vector<int> total;
for(int i = x.value.size()-1; i>=0; --i){
for(int j = y.value.size()-1, k = 0; j>=0; --j, ++k){
temp = x.value[i] * y.value[j];
if (total.size() <= (i + multi + 1))
total.resize(i + multi + 1 + 1);
total[i + multi] += (temp % 10);
temp = (temp - total[i]) / 10;
total[i + multi + 1] += temp;
}
multi++;
}
reverse(total.begin(), total.end());
return newTotal;
}
В основном я застрял в перегруженной части умножения.Остальное, я думаю, я получил.
Спасибо, Ноа