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

C++

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

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

28.01.2010, 19:29. Просмотров 3148. Ответов 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";
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.01.2010, 19:29     Генератор судоку
Посмотрите здесь:

решение судоку C++
C++ Решение Судоку
C++ Судоку!
почти судоку) C++
Судоку в Visual C++ Visual C++
проверка судоку C++
C++ Судоку
Судоку C++
C++ Судоку
C++ Судоку си++
C++ Судоку

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
insideone
Модератор
Автор FAQ
3635 / 913 / 48
Регистрация: 10.01.2010
Сообщений: 2,460
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 минут
Как вариант: это же не гениальная программа которой будут пользоваться миллиарды людей. Может ввести счетчик и если она выполняется слишком долго - сбросится и попытаться по другому? Видимо есть данные которые не сходятся
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";
}
Kill_overdose
Сообщений: n/a
18.06.2012, 14:42     Генератор судоку #4
Пожалуйста кто может напишите комментарии к этой программе хочу разобраться, но никак не могу(((Заранее спасибо=)
Yandex
Объявления
18.06.2012, 14:42     Генератор судоку
Ответ Создать тему
Опции темы

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