Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

C++

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 26, средняя оценка - 4.77
OVERPOWER8
19 / 19 / 1
Регистрация: 29.11.2009
Сообщений: 224
#1

Генератор судоку - C++

28.01.2010, 19:29. Просмотров 3265. Ответов 3
Метки нет (Все метки)

Маленькая проблемка с программой - в одном из 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
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.01.2010, 19:29
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Генератор судоку (C++):

Судоку! - C++
Почти написал программу для генерирования судоку. Компилируется, работает, однако в 50% случаях генерирует только 3-8 строк и зависает. В...

генератор чисел - C++
здравствуйте, уважаемые форумчане! есть вопрос - возможно ли сделать генератор случайных чисел с заданными пределами чисел. к примеру от...

Сделать свой генератор случайных чисел - C++
Всем привет. Не уверен в какую тему это писать, поэтому пишу здесь, по привычке. Необходимо сделать формулу по которой будут...

Генератор с возможность создания более 3 млрд паролей и выводом в файл - C++
Ребята, кто сможет достать код из программы, или написать на с++ Нужен просто такой генератор с возможность создания более 3 млрд паролей...

Игра судоку (крестики-нолики) - C++ Builder
Люди подскажите пожалуйста. Препод дал задание написать игру судоку ну типа крестики нолики. Поле 9 на 9 . Выигрывает в том случае если 5...

Судоку: рандомное заполнение массива - C++ Builder
Вот заполнение рандомом масива. Рандомно как то повторяющих елементов много подскажите может кто делал? { for(i=1; i&lt;9; i++){ ...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
insideone
Модератор
Автор FAQ
3639 / 918 / 49
Регистрация: 10.01.2010
Сообщений: 2,469
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
OVERPOWER8
19 / 19 / 1
Регистрация: 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
Сообщений: n/a
18.06.2012, 14:42 #4
Пожалуйста кто может напишите комментарии к этой программе хочу разобраться, но никак не могу(((Заранее спасибо=)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.06.2012, 14:42
Привет! Вот еще темы с ответами:

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

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

Возможно ли создать генератор игры Судоку скриптом БАТ - CMD/BAT
На других языках тема изъеденная (на этом сайте тоже) на БАТе не нашел. Вообще возможно? Генерировать таблицу 9 на 9 в случайном порядке....

Переделать обычное судоку в судоку чёт-нечёт - Delphi
Здравствуйте. Помогите, пожалуйста, переделать обычное судоку 9х9 в судоку чёт-нечёт. Отличие судоку чёт-нечёт заключается в том, что на...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
18.06.2012, 14:42
Ответ Создать тему
Опции темы

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