2016-04-22 79 views
-1

我的输出很正确,即时读取文件中的数组,并且总结他们的行,列和对角线总数。除了我的布尔值isMagic(),一切正常。如果所有的和都相等,则返回true,否则返回false;我的布尔值每次都返回false,C++,arrays,Magic Box

当编码我输入的左右对角线和的方法(int大小),因为它不允许我将这些int与rowTotal(row)和colTotal(col)进行比较..只要我可以告诉这个不影响我的整体代码。我只需要布尔值就可以正确返回。有任何想法吗?

// Purpose: Magic BOX... 
#include <iostream> 
#include <cstdlib> 
#include <fstream> 

using namespace std; 

int size= 0; 
int box [][10]= {}; 

void ReadIn(ifstream& fin) 
{ 
    box[size][size]; 
     for(int i = 0; i<size;++i) 
     { 
      for(int j= 0; j<size;++j) 
       fin>> box[i][j]; 
     } 
    cout<<"\n"; 
} 

int rowTotal(int row) 
{ 
    int total = 0; 
    for(int i = 0; i<size; ++i) 
     total+= box[row][i]; 
    return total; 
} 

int colTotal(int col) 
{ 
    int total = 0; 
    for(int i=0; i<size; ++i) 
     total += box[i][col]; 
    return total; 
} 

int rightdiagonal(int size) 
{ 
    int total = 0; 
    for(int i=0; i<size; ++i) 
     total+= box[i][i]; 
     return total; 
} 

int leftdiagonal(int size) 
{ 
    int total = 0; 
    int j=size-1; 
    for(int i=0; i<size; ++i) 
     { 
      total+= box[i][j]; 
      j--; 
     } 
     return total; 
} 
bool isMagic() 
{ 
    if(rowTotal != rightdiagonal) 
     return false; 
    if(colTotal != rightdiagonal) 
     return false; 
    if(rightdiagonal != leftdiagonal) 
     return false; 

    else return true; 
} 

void print(int& count) 
    { 
     int row=0, col=0; 
     cout<< "==========="<<"\n"<< "===Box "<< count<<"==="<<"\n"<<"==========="<<endl; 
     for(int i = 0; i < size; ++i) 
       { 
        for(int j = 0; j<size; ++j) 
         { 
          cout<<box[i][j]<<" "; 
         } 
        cout<<"\n"; 
       } 
     cout<<"\n"; 

    } 


int main() 
{ 
    int count = 1; 
    ifstream fin ("magicbox.txt"); 
    fin>>size; 

    while(size != -1) 
    { 
     ReadIn(fin); 
     print(count); 
       for (int i=0; i<size; ++i) 
       { 
        int row=0; 
        rowTotal(row); 
        cout<<"The sum of row "<< row<< " is "<< rowTotal(row)<< endl; 
        row++; 
       } 
     cout<< "\n"; 
     for(int i = 0; i < size; ++i) 
       { 
        int col=0; 
        colTotal(col); 
        cout<<"The sum of column "<< col<< " is "<< colTotal(col)<< endl; 
        col++; 
       } 
      cout<<"\n"; 
      rightdiagonal(size); 
      cout<<"The sum of the right diagonal is " << rightdiagonal(size)<< endl; 

      leftdiagonal(size); 
      cout<<"The sum of the left diagonal is " << leftdiagonal(size)<< endl; 
     isMagic(); 
     if(isMagic() == true) 
      cout<<"This matrix IS a magic box!"<<endl; 
     else 
      cout<<"This matrix is NOT a magic box."<< endl; 

     fin>>size; 
     count++;  
    } 
} 
+2

你认为“box [size] [size]”会做什么?你的数组是一行(或可能为零行)和十列的静态变量。 – gnasher729

+3

有时它有助于将代码去除到显示问题的最小代码。通常这增加了清晰度,你可以解决你自己。 –

+1

是的,我不知道你认为'box [size] [size]'在做什么,但它绝对不是这样做的。 _请正确开始缩进(这实际上很难读),特别是在条件块中;由于误导你的一些缩进 - GCC 6将会在这一天有一个这样的代码 - 这可能会导致你在一天之后的一天。出于同样的原因,请考虑总是围绕有条件的块使用大括号,因为忽略它们,可能会在以后发生可怕的错误,而这些错误在以后你真的不应该这样做。 –

回答

1

这是完全错误的

bool isMagic() 
{ 
    if(rowTotal != rightdiagonal) 
     return false; 
    if(colTotal != rightdiagonal) 
     return false; 
    if(rightdiagonal != leftdiagonal) 
     return false; 

    else return true; 
} 

rowTotal和rightdiagonal的功能。这意味着什么比较他们

你的意思

bool isMagic() 
{ 
int rd = rightDiagonal(size); 
int ld = leftDiagonal(size); 
if(ld != rd) 
    return false; 

// etc 
} 

你需要做大量的列总数和行总计求和太

还你不需要大小通入总额的功能,其一个全局变量

+0

因为我把它们作为整数返回,我认为它们被认为是整数值? –

+0

@ Cpt.Awesome:注意在解决方案中,函数调用的结果以整数存储。整数然后进行比较。比较返回'bool'类型。您需要查看执行函数的语法。 –