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

Решение Судоку - C++

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 129, средняя оценка - 4.81
HeddinG
 Аватар для HeddinG
0 / 0 / 0
Регистрация: 23.06.2009
Сообщений: 16
24.06.2009, 23:39     Решение Судоку #1
Здравствуйте!

Заранее извеняюсь за повтор, писал такую тему в алгоритмах, но там глухо

Интересует алгоритм для программы, которая решает Судоку. Те, что обсуждались тут - не подходят. Мне ненравиться программа которая вылетает если однозначных вариантов подстановки нет.
Знаю, что нужна рекурсия, попытался написать, но мало что получилось (С++):

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
bool Sudoku::Anser ()
{
        if (
                Calculation(0,0) && Calculation(0,1) && Calculation(0,2) && Calculation(0,3) && Calculation(0,4) && Calculation(0,5) && Calculation(0,6) && Calculation(0,7) && Calculation(0,8) &&
                Calculation(1,0) && Calculation(1,1) && Calculation(1,2) && Calculation(1,3) && Calculation(1,4) && Calculation(1,5) && Calculation(1,6) && Calculation(1,7) && Calculation(1,8) &&
                Calculation(2,0) && Calculation(2,1) && Calculation(2,2) && Calculation(2,3) && Calculation(2,4) && Calculation(2,5) && Calculation(2,6) && Calculation(2,7) && Calculation(2,8) &&
                Calculation(3,0) && Calculation(3,1) && Calculation(3,2) && Calculation(3,3) && Calculation(3,4) && Calculation(3,5) && Calculation(3,6) && Calculation(3,7) && Calculation(3,8) &&
                Calculation(4,0) && Calculation(4,1) && Calculation(4,2) && Calculation(4,3) && Calculation(4,4) && Calculation(4,5) && Calculation(4,6) && Calculation(4,7) && Calculation(4,8) &&
                Calculation(5,0) && Calculation(5,1) && Calculation(5,2) && Calculation(5,3) && Calculation(5,4) && Calculation(5,5) && Calculation(5,6) && Calculation(5,7) && Calculation(5,8) &&
                Calculation(6,0) && Calculation(6,1) && Calculation(6,2) && Calculation(6,3) && Calculation(6,4) && Calculation(6,5) && Calculation(6,6) && Calculation(6,7) && Calculation(6,8) &&
                Calculation(7,0) && Calculation(7,1) && Calculation(7,2) && Calculation(7,3) && Calculation(7,4) && Calculation(7,5) && Calculation(7,6) && Calculation(7,7) && Calculation(7,8) &&
                Calculation(8,0) && Calculation(8,1) && Calculation(8,2) && Calculation(8,3) && Calculation(8,4) && Calculation(8,5) && Calculation(8,6) && Calculation(8,7) && Calculation(8,8)
                )
                return true;
//      Add (pole_tmp);
        return false;
}
bool Sudoku::Calculation (int I, int K, int C)
{
        if (pole_tmp[i][K])
                return true;
        if (!Verification(I,K,C))       // Перебераються возможные цифры для поля
        {
                if (C<9)
                        Calculation (I,K,C+1);
                else
                        return false;
        }
        else
        {
                pole[i][K]=C;
                return true;
        }
}
bool Sudoku::Verification(int I, int K, int C)
{
        //----------------------- проверка совпадений по вертикали
        for (int i=I+1;i<9;i++)
        {
                if (pole[i][K]==C)
                        return false;
        }
        for (int ii=I-1;ii>=0;ii--)
        {
                if (pole[ii][K]==C)
                        return false;
        }
        //----------------------- проверка совпадений по горизонтали
        for (int k=K+1;k<9;k++)
        {
                if (pole[i][k]==C)
                        return false;
        }
        for (int kk=K-1;kk>=0;kk--)
        {
                if (pole[i][kk]==C)
                        return false;
        }
        return true;
}
Нашел кое-что у Д.Кнута - Dancing Links (http://www.sudopedia.org/wiki/Dancing_Links).
Но там англ, для меня это сложновато

Если кто сталкивался - напишите плз хотя-бы алгоритм.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.06.2009, 23:39     Решение Судоку
Посмотрите здесь:

решение судоку C++
почти судоку) C++
проверка судоку C++
C++ Судоку
Судоку C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16821 / 5242 / 318
Регистрация: 30.03.2009
Сообщений: 14,118
Записей в блоге: 26
27.02.2011, 17:39     Решение Судоку #21
Цитата Сообщение от dipic Посмотреть сообщение
А как можно получить код, если у меня Вижуал Студия 2008-я .. ?
При такой постановке вопроса сразу же ищи вариант под твою студию. У меня нет никакого желания пояснять, как взять исходник и скомпилять его под студией. Тем более потом выяснится, что консольный вариант тебя не устроит и нужен графический. Хотя возможно кто-то и захочет объяснять, но я - пас

Добавлено через 9 минут
В примере из поста #7 надо скомпилять все исходники из каталогов solver и ui_example_classic
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
slice
32 / 75 / 4
Регистрация: 04.11.2010
Сообщений: 249
27.02.2011, 21:43     Решение Судоку #22
Evg, писать сmake уже не труЪ?
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16821 / 5242 / 318
Регистрация: 30.03.2009
Сообщений: 14,118
Записей в блоге: 26
27.02.2011, 22:33     Решение Судоку #23
Цитата Сообщение от slice Посмотреть сообщение
Evg, писать сmake уже не труЪ?
А зачем?
slice
32 / 75 / 4
Регистрация: 04.11.2010
Сообщений: 249
27.02.2011, 22:45     Решение Судоку #24
Evg
удобно, не?
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16821 / 5242 / 318
Регистрация: 30.03.2009
Сообщений: 14,118
Записей в блоге: 26
27.02.2011, 23:13     Решение Судоку #25
Цитата Сообщение от slice Посмотреть сообщение
Evg
удобно, не?
Скриптом удобнее. Один фиг, 2 секунды компилится, а makefile ещё писать надо
slice
32 / 75 / 4
Регистрация: 04.11.2010
Сообщений: 249
27.02.2011, 23:22     Решение Судоку #26
Evg
зато под вижуал студией без дополнительных телодвижений собралось бы.
dipic
2 / 2 / 0
Регистрация: 09.12.2010
Сообщений: 45
28.02.2011, 17:58     Решение Судоку #27
Evg,
Да, надо на вижуал си %)
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16821 / 5242 / 318
Регистрация: 30.03.2009
Сообщений: 14,118
Записей в блоге: 26
28.02.2011, 18:06     Решение Судоку #28
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Цитата Сообщение от dipic Посмотреть сообщение
Evg,
Да, надо на вижуал си %)
Бери учебник по вижуал Си. Прочитай его. Освой. А потом включи мозги и немного напряги их, чтобы понять, как готовый исходник засунуть в вижуал Си.

Задорнов в своё время обсирал америкосов, что дескать если у них врач - специалист по правой руке, то левую руку он вылечить не сможет. У нас, по ходу дела, страна катится к тому же самому
dipic
2 / 2 / 0
Регистрация: 09.12.2010
Сообщений: 45
28.02.2011, 23:38     Решение Судоку #29
Я только недавно начал вижуал вообще говоря осваевать. Немного разобрался (но просто знаешь, чисто человеческий фактор - не нравится, человек же ш никогда не будет делать то, что его заставляют делать, или же делать, но при этом даже не задумываясь как. Вот у меня аналогично - кодить - ну не мое это, а преподы требуют - вот и приходиться. А душа и тело все в дизайне.. Аналогично и с фри-лансом - есть команда в которой версткой занимаюсь уж явно не я.. Это чисто лирическое отступление). Спасибо за советы! Надеюсь можно будет спрашевать по ходу дела, вдруг что??
С ув. Богдан.
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16821 / 5242 / 318
Регистрация: 30.03.2009
Сообщений: 14,118
Записей в блоге: 26
28.02.2011, 23:50     Решение Судоку #30
Цитата Сообщение от dipic Посмотреть сообщение
Я только недавно начал вижуал вообще говоря осваевать
Могу привести аналогичное понятие: "циркуль для третьего класса". Расшифровка: циркуль - он и в африке циркуль, а для какого он класса, роли не играет. Так же и с консольным приложением.

Если вопрос из разряда "сам я не умею, учиться не хочу, но сделать надо", то зайди в этот раздел. За символическую сумму тебе засунут исходник в вижуал студио. Хотя сразу скажу, что постановка задачи находится на уровне "за деньги открыть текстовый файл, прочитать его и записать в другой файл"
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
01.03.2011, 00:41     Решение Судоку
Еще ссылки по теме:

C++ Судоку
C++ Судоку си++
Нужна проверка, имеет ли судоку решение C++

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

Или воспользуйтесь поиском по форуму:
dipic
2 / 2 / 0
Регистрация: 09.12.2010
Сообщений: 45
01.03.2011, 00:41     Решение Судоку #31
Evg,
та нет, какраз таки хочеться научится хотябы чему-то. Ведь еще впереди таких 4 года %) Да и кто его знает, может со временем открою в себе талант кодера. Я понял. Спасибо!
Yandex
Объявления
01.03.2011, 00:41     Решение Судоку
Ответ Создать тему
Опции темы

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