Web Toolbar by Wibiya

Pages

Wednesday, January 23, 2013

Sudoku Solver!

Solution: Below is the code to solve a sudoku.
/*
Input Matrix:
 7  0  0  1  0  0  0  0  0 
 0  2  0  0  0  0  0  1  5 
 0  0  0  0  0  6  3  9  0 
 2  0  0  0  1  8  0  0  0 
 0  4  0  0  9  0  0  7  0 
 0  0  0  7  5  0  0  0  3 
 0  7  8  5  0  0  0  0  0 
 5  6  0  0  0  0  0  4  0 
 0  0  0  0  0  1  0  0  2 
*/

#define TRUE 1
#define FALSE 0
#define N 9
int S[N+1][N+1] = {0,};

void printMat(int S[][N+1])
{
    int i = 0;
    int j = 0;


    for(i=1; i<=N; i++) {
        for(j=1; j<=N; j++) {
            printf("%2d ", S[i][j]);
        }
        printf("\n");
    }
}

void initMat(int S[][N+1])
{
    S[1][1] = 7;
    S[1][4] = 1;

    S[2][2] = 2;
    S[2][8] = 1;
    S[2][9] = 5;

    S[3][6] = 6;
    S[3][7] = 3;
    S[3][8] = 9;

    S[4][1] = 2;
    S[4][5] = 1;
    S[4][6] = 8;
    
    S[5][2] = 4;
    S[5][5] = 9;
    S[5][8] = 7;

    S[6][4] = 7;
    S[6][5] = 5;
    S[6][9] = 3;

    S[7][2] = 7;
    S[7][3] = 8;
    S[7][4] = 5;

    S[8][1] = 5;
    S[8][2] = 6;
    S[8][8] = 4;

    S[9][6] = 1;
    S[9][9] = 2;
}

int permitted(int S[][N+1], int i, int j, int a)
{
    int x;

    for(x=1; x<=N; x++) {
        if(S[i][x] == a) {
            return FALSE;
        }
    }

    for(x=1; x<=N; x++) {
        if(S[x][j] == a) {
            return FALSE;
        }
    }

    return TRUE;
}

void solve(int S[][N+1], int i, int j)
{
    int a = 0;

    /*
     * this row is filled, jump to next row
     */
    if(j > N) {
        j = 0;
        i++;
    }

    /*
     * all rows are filled, print sol. and exit
     */
    if(i > N) {
        printMat(S);
        printf("\n");
        exit(0);
    }

    /*
     * each cell can take a value belonging to [1,9]
     */
    for(a=1; a<=N; a++) {
        /*
         * cell is already occupied, move to next cell
         */
        if (S[i][j]) {
            solve(S, i, j+1);
            return;
        }
        else if (permitted(S, i, j, a)) {
            S[i][j] = a;
            solve(S, i, j+1);
            S[i][j] = 0;
        } else {
            continue;
        }
    }
}

int main()
{
    initMat(S);
    printMat(S);
    printf("\n");
    solve(S, 1, 1);
}

1 comment:

Anonymous said...

Why do we do x[i][j] = 0; after the solve call?