分段错误:11(数独板)

时间:2016-10-05 05:09:51

标签: c++ segmentation-fault g++ clang++ sudoku

当我尝试在我的程序中显示我的数独板时,终端说:Segmentation fault: 11

以下是我的代码的副本:

#include <iostream>
using namespace std;

const int DIMEN = 9;

void generate_valid(int [][DIMEN]);
// generate a valid sudoku solution in a DIMENxDIMEN board

int main()
{
    int valid_board[DIMEN][DIMEN];
    // Declare the valid board array

    generate_valid(valid_board);
    // Initialize the board -- a valid solution

    for (int i = 0; i < DIMEN; i++)
    {
        for (int j = 0; i < DIMEN; j++)
        {
            cout << valid_board[i][j];
            cout << " ";
        }
        cout << endl;
    }
    return 0;
}

void generate_valid(int valid[][DIMEN])
 {
    // initialize the board array -- legit solution
    for( int i = 0; i < DIMEN; i++ ) {
        for( int j = 0; j < DIMEN; j++) {
            // ROW ZERO: 0,1,2,...,9
            if( i == 0 )
                valid[i][j] = j % DIMEN + 1;
            // ROWS 1 AND 2: 4,5,6... and 7,8,9...
            else if( i == 1 || i == 2 )
                valid[i][j] = (j + (i*3)) % (DIMEN) + 1;
            // ROWS 3 AND 6: 2,3,4,... and 3,4,5,...
            else if( i % 3 == 0 ) 
                valid[i][j] = (j + (i/3) ) % DIMEN + 1;
            // ROWS 4 AND 8: 5,6,7,... and 9,1,2,...
            else if (i % 4 == 0 )
                valid[i][j] = (j+i) % DIMEN + 1;
            // ROW 5: 8,9,1...
            else if( i == 5 )
                valid[i][j] = (j+7) % DIMEN + 1;
            // ROW 7: 6,7,8,...
            else if( i == 7 )
                valid[i][j] = (j+5) % DIMEN + 1;
        }
    }
 }

我做错了什么?从我在其他关于此错误的帖子中读到的内容,这与使用大量内存的程序有关,但这只在sudoku板上使用了81个整数。

1 个答案:

答案 0 :(得分:1)

for (int j = 0; i < DIMEN; j++)

将其更改为:

for (int j = 0; j < DIMEN; j++)

由于j不受限制地增加,valid_board[i][j]将访问不属于您的程序的内存位置,因此会Segmentation Fault