我正在做一个bigint项目,我很难过为什么我的加法运算符在测试用例上没有正常工作。
我排除了.h文件,因为它可能不必要。
#include "bigint.h"
#include<iostream>
#include<fstream>
#include<cstdlib>
#include<cassert>
bigint::bigint()
{ //Default constructor that sets digit to ZERO
for (int i = 0; i < MAX; i++)
{
digits[i] = 0;
}
}
bigint::bigint(int n)
{
for(int i = 0; i < MAX; ++i) //Sets the digit to ZERO
digits[i] = 0;
for (int i = 0; n != 0 ; ++i)
{
digits[i] = (n % 10); //
n = n / 10;
}
}
bigint::bigint(const char new_digits[])
{
int null = 0;
int temp = 0;
for(int i = 0; i < MAX; ++i)
{
digits[i] = 0;
}
while(new_digits[null] != '\0')
++null;
--null;
temp = null;
for(int j = 0; j < MAX && temp >= 0; ++j)
{
digits[j] = new_digits[temp] - '0';
temp -= 1;
}
}
bool bigint::operator==(const bigint& equal) const
{
int i = 0;
while(i < MAX)
{
if(digits[i] != equal.digits[i])
{
return false;
}
++i;
}
return true;
}
std::ostream& operator<<(std::ostream& output, const bigint& source)
{
int sub1 = MAX - 1; //subtracts 1 from the maximum size
while(source.digits[sub1] == 0)
{
--sub1; //EMPTY
}
while(sub1 > -1)
{
output << source.digits[sub1];
--sub1;
}
std::cout << std:: endl;
return output;
}
std::istream& operator>>(std::istream& in, bigint& source)
{
char getdata[MAX];
char user_input;
int i = 0;
in.get(user_input);
while(!in.eof() && user_input != ';')
{
in.get(user_input);
source.digits[i] = user_input;
++i;
}
source = bigint(getdata);
return in;
}
char bigint::operator[](const int i)
{
return digits[i];
}
bigint bigint::operator+(const bigint rhs)
{
bigint result;
int i = 0;
for( ; i < MAX; ++i)
{
if((digits[i] + rhs.digits[i]) > 9)
{
digits[i+1] = digits[i+1] + 1 ;
}
result.digits[i] = (digits[i] + rhs.digits[i]);
result.digits[i] = result.digits[i] % 10;
}
return result;
}
int main()
{
// Setup fixture
bigint left("1");
bigint right("9");
bigint result;
// Test
result = (left + right);
Verify
assert(left == "1");
assert(right == "9");
assert(result == "10");
}
在此测试用例中,程序在assert(result ==“10”);
中止但是如果我有相同的测试用例,除了断言(结果== 10); 程序运行。
谁能说出原因?
答案 0 :(得分:3)
首先,你应该实现赋值运算符bigint::operator=(const bigint&)
。
现在,在operator+
中,您正在改变左侧对象的内容,在此代码中:
if((digits[i] + rhs.digits[i]) > 9)
{
digits[i+1] = digits[i+1] + 1 ;
}
那不好。例如,如果您运行此代码:
bigint x("5");
bigint y("6");
x+y;
x+y;
最终x
为17。
接下来,您通过值传递bigint::operator
参数,您应该通过 reference (&
)传递。
最后,你在这里的缩进是恶意的:
while(new_digits[null] != '\0')
++null;
--null;
这里的循环体是什么?这是对的,而不是第三行。请不要缩进这样的代码,它会让小猫哭泣。编程小猫,至少。
注意:我在这里看不到任何动态内存分配代码,这意味着digits
可能是一个静态大小的数组。确保它足够大,如果你打算这样做,并且要知道如果超出它的尺寸就会中断。