Форум программистов, компьютерный форум, киберфорум
C++
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.57/37: Рейтинг темы: голосов - 37, средняя оценка - 4.57
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
1

Генератор судоку

28.01.2010, 19:29. Показов 7059. Ответов 4
Метки нет (Все метки)

Маленькая проблемка с программой - в одном из 10 случаев программа зависает.
Кому не сложно, прошу проверить и исправить.

Вот полный работающий код:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
#include <iostream>
#include <cstdlib>
using namespace std;
 
const int SIZE = 9;
int sudoku[SIZE][SIZE];
int test_array[SIZE*SIZE][SIZE] = {0};
 
bool checkrow(int, int);
bool checkcol(int, int);
bool checksqr(int, int);
bool test(int, int);
void moveback(int& i, int& j);
void write(int i, int j);
void print();
 
int main()
{
    srand(rand() ^ time(0));
    
    int i, j;
    for(i=0; i<9; i++)
    {
        for(j=0; j<9; j++)
        {
            for(;;)
            {
                if(!test(i, j))
                    moveback(i, j);
                
                sudoku[i][j] = rand()%9+1;
                write(i, j);
                
                if(checksqr(i, j) && checkrow(i, j) && checkcol(i, j) )
                    break;
            }
        }
    }
    
     print();
    
    return 0;
    
}
 
bool checkrow(int x, int y)
{
    for(int i=0; i<y; i++)
        if(sudoku[x][i] == sudoku[x][y])
            return false;
 
    return true;
}
 
bool checkcol(int x, int y)
{
    for(int i=0; i<x; i++)
        if(sudoku[i][y] == sudoku[x][y])
            return false;
    
    return true;
}
 
bool checksqr(int x, int y)
{ 
    int i_start = x/3;      i_start *= 3;
    int j_start = y/3;      j_start *= 3;
    
    for(int i=i_start; i < i_start+3; i++)
        for(int j=j_start; j < j_start+3; j++)
        {
            if(i==x && j==y)
                return true;
            
            if(sudoku[i][j] == sudoku[x][y])
                return false;
        }
    return true;
}
 
bool test(int i, int j)
{
    int current = i*9 +j+1;
    
    for(int x=1; x<9; x++)
        if( test_array[current][x] == 0)
            return true;
 
    return false;
}
 
void moveback(int& i, int& j)
{
    int current = i*9 +j+1;
    
    for(int x=0; x<9; x++)
        test_array[current][x] = 0;
    
    if(j < 1)
    {
        i--;    j=8;
    }
    else
        j--;
}
 
void write(int i, int j)
{
    int current = i*9 + j+1;
    int value = sudoku[i][j];
    test_array[current][value] = 1;
}
 
void print()
{
    int i, j;
    
    for(i=0; i<9; i++)
    {
        if( i%3 == 0 )
            cout << "=========================\n";
        
        cout << "| ";
        
        for(j=0; j<9; j++)
        {
            cout << sudoku[i][j] << " ";
            
            if((j+1)%3 == 0)
                cout << "| ";
        }
        
        cout << endl;
    }
        cout << "=========================\n";
}
0

Помощь в написании контрольных, курсовых и дипломных работ здесь.

Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
28.01.2010, 19:29
Ответы с готовыми решениями:

Судоку!
Почти написал программу для генерирования судоку. Компилируется, работает, однако в 50% случаях...

Таблица для игры Судоку
У меня задача сделать игру Судоку. Я пробовал рисовать таблицу для значений через StringGrid, но не...

Судоку: рандомное заполнение массива
Вот заполнение рандомом масива. Рандомно как то повторяющих елементов много подскажите может кто...

Игра судоку (крестики-нолики)
Люди подскажите пожалуйста. Препод дал задание написать игру судоку ну типа крестики нолики. Поле...

4
Автор FAQ
3684 / 961 / 114
Регистрация: 10.01.2010
Сообщений: 2,550
30.01.2010, 20:14 2
C++
1
2
if(checksqr(i, j) && checkrow(i, j) && checkcol(i, j) )
   break;
Вот тут она зависает. В смысле поймал что break не выполняется.

А хотя нет... дело не в этом

C++
1
2
3
4
5
6
7
8
9
10
11
                        for(;;)
                        {
                                if(!test(i, j))
                                        moveback(i, j);
                                
                                sudoku[i][j] = rand()%9+1;
                                write(i, j);
                                
                                if(checksqr(i, j) && checkrow(i, j) && checkcol(i, j) )
                                        break;
                        }
Только что i = 5 а j становится то 6 то 5, то 7, то 4... и зациклилось

i 5 int
j 7 int
- sudoku 0x00419148 int (* sudoku)[9] int [9][9]
- [0] 0x00419148 int (* sudoku)[9] int [9]
[0] 9 int
[1] 4 int
[2] 5 int
[3] 6 int
[4] 3 int
[5] 7 int
[6] 2 int
[7] 1 int
[8] 8 int
- [1] 0x0041916c int [9]
[0] 6 int
[1] 8 int
[2] 1 int
[3] 2 int
[4] 4 int
[5] 5 int
[6] 3 int
[7] 9 int
[8] 7 int
- [2] 0x00419190 int [9]
[0] 7 int
[1] 3 int
[2] 2 int
[3] 1 int
[4] 9 int
[5] 8 int
[6] 4 int
[7] 5 int
[8] 6 int
- [3] 0x004191b4 int [9]
[0] 1 int
[1] 2 int
[2] 9 int
[3] 7 int
[4] 5 int
[5] 3 int
[6] 6 int
[7] 8 int
[8] 4 int
- [4] 0x004191d8 int [9]
[0] 5 int
[1] 6 int
[2] 4 int
[3] 9 int
[4] 8 int
[5] 1 int
[6] 7 int
[7] 3 int
[8] 2 int
- [5] 0x004191fc int [9]
[0] 3 int
[1] 7 int
[2] 8 int
[3] 4 int
[4] 6 int
[5] 2 int
[6] 5 int
[7] 4 int
[8] 0 int
- [6] 0x00419220 int [9]
[0] 0 int
[1] 0 int
[2] 0 int
[3] 0 int
[4] 0 int
[5] 0 int
[6] 0 int
[7] 0 int
[8] 0 int
- [7] 0x00419244 int [9]
[0] 0 int
[1] 0 int
[2] 0 int
[3] 0 int
[4] 0 int
[5] 0 int
[6] 0 int
[7] 0 int
[8] 0 int
- [8] 0x00419268 int [9]
[0] 0 int
[1] 0 int
[2] 0 int
[3] 0 int
[4] 0 int
[5] 0 int
[6] 0 int
[7] 0 int
[8] 0 int
Добавлено через 11 минут
Как вариант: это же не гениальная программа которой будут пользоваться миллиарды людей. Может ввести счетчик и если она выполняется слишком долго - сбросится и попытаться по другому? Видимо есть данные которые не сходятся
0
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
31.01.2010, 11:30  [ТС] 3
Исправил программу. Вот окончательная версия:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
#include <iostream>
#include <cstdlib>
using namespace std;
 
const int SIZE = 9;
int sudoku[SIZE][SIZE];
int test_array[SIZE*SIZE][SIZE] = {0};
 
bool checkrow(int, int);
bool checkcol(int, int);
bool checksqr(int, int);
bool test(int, int);
bool CheckRepeated(int i, int j);
void moveback(int& i, int& j);
void write(int i, int j);
void print();
 
int main()
{
    srand(time(0));
    
    int i, j;
    for(i=0; i<9; i++)
    {
        for(j=0; j<9; j++)
        {
            for(;;)
            {
                if(!test(i, j))
                    moveback(i, j);
                
                sudoku[i][j] = rand()%9+1;
                
                if(CheckRepeated(i, j))
                    continue;
                    
                write(i, j);
                if(checksqr(i, j) && checkrow(i, j) && checkcol(i, j) )
                    break;
            }
        }
    }
    
     print();
    
    return 0;
    
}
 
bool checkrow(int x, int y)
{
    for(int i=0; i<y; i++)
        if(sudoku[x][i] == sudoku[x][y])
            return false;
 
    return true;
}
 
bool checkcol(int x, int y)
{
    for(int i=0; i<x; i++)
        if(sudoku[i][y] == sudoku[x][y])
            return false;
    
    return true;
}
 
bool checksqr(int x, int y)
{ 
    int i_start = x/3;      i_start *= 3;
    int j_start = y/3;      j_start *= 3;
    
    for(int i=i_start; i < i_start+3; i++)
        for(int j=j_start; j < j_start+3; j++)
        {
            if(i==x && j==y)
                return true;
            
            if(sudoku[i][j] == sudoku[x][y])
                return false;
        }
    return true;
}
 
bool test(int i, int j)
{
    int current = i*9 +j+1;
    
    for(int x=1; x<9; x++)
        if( test_array[current][x] == 0)
            return true;
 
    return false;
}
 
bool CheckRepeated(int i, int j)
{
    int value = sudoku[i][j];
    int current = i*9 +j+1;
    
    if(test_array[current][value] == 1)
        return true;
    else
        return false;
}
 
void moveback(int& i, int& j)
{
    int current = i*9 +j+1;
    
    for(int x=1; x<=9; x++)
        test_array[current][x] = 0;
    
    if(j < 1)
    {
        i--;    j=8;
    }
    else
        j--;
}
 
void write(int i, int j)
{
    int current = i*9 + j+1;
    int value = sudoku[i][j];
    test_array[current][value] = 1;
}
 
void print()
{
    int i, j;
    
    for(i=0; i<9; i++)
    {
        if( i%3 == 0 )
            cout << "=========================\n";
        
        cout << "| ";
        
        for(j=0; j<9; j++)
        {
            cout << sudoku[i][j] << " ";
            
            if((j+1)%3 == 0)
                cout << "| ";
        }
        
        cout << endl;
    }
        cout << "=========================\n";
}
1
Kill_overdose
18.06.2012, 14:42 4
Пожалуйста кто может напишите комментарии к этой программе хочу разобраться, но никак не могу(((Заранее спасибо=)
0 / 0 / 0
Регистрация: 22.12.2020
Сообщений: 6
22.12.2020, 12:49 5
А почему работает? В функции moveback() есть обращение к элементу test_array[current][x], где x от 1 до 9 включительно и, по идее, есть выход за границы массива (test_array[current][9] когда x = 9)!?
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
22.12.2020, 12:49

Как составить цикл? Игра судоку.
Здраствуйте препод задал написать игру судоку(крестики нолики) поле 9 на 9 ячеек. Выйгрыш в том...

Судоку в Visual C++
Все доброго времени суток! Вот стоит передо мною задача сделать игру Судоку (принцип которой даже...

Разработать генератор квадрата Судоку с++
Привет ребят, нужно разработать Разработать генератор квадрата Судоку с++ 9х9, азработать...

Судоку
6. (6 и 7 лабораторная работа) – Судоку. (6 – заполнение массива).


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.