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

С++ для начинающих

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

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

24.06.2009, 23:39. Просмотров 17782. Ответов 30
Метки нет (Все метки)

Здравствуйте!

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

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

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).
Но там англ, для меня это сложновато

Если кто сталкивался - напишите плз хотя-бы алгоритм.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.06.2009, 23:39
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Решение Судоку (C++):

решение судоку - C++
Судоку размера n называется квадрат со стороной n2, разделенный на n2 средних квадратов со стороной n, каждый из которых разделен на n2...

Генерация и решение судоку - C++
Никто не знает ,если ли статья про решение и ,главное, генерацию судоку с различными эвристиками с кодом на c++ или c# англоязычный или...

Нужна проверка, имеет ли судоку решение - C++
Здравтсвуйте! В данный момент пишу программу которая решает судоку: Критика кода приветствуется. main.cpp #include...

Судоку - C++
Помогите написать игру судоку. я программирую в С++. Мне дали задание написать игру судоку в консольке. Только без всяких наворотов,...

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

Судоку си++ - C++
Подскажите пожалуйста как правильно создать таблицу 9*9 для ввода значений?

30
PointsEqual
ниначмуроФ
836 / 520 / 33
Регистрация: 12.10.2009
Сообщений: 1,915
27.01.2010, 03:18 #16
вот тут www.deco.tu2.ru есть исходник программы, которая решает судоку, только она на делфи, но думаю переделать не сложно будет
0
K17
0 / 0 / 0
Регистрация: 07.02.2011
Сообщений: 3
08.02.2011, 00:37 #17
мое решение на Java: http://sites.google.com/site/sudokujavasolution/
0
dipic
2 / 2 / 0
Регистрация: 09.12.2010
Сообщений: 45
27.02.2011, 16:02 #18
Можете помочь. Я так понимаю у кого то можно взять готовый код? Не поможете??
0
Evg
Эксперт CАвтор FAQ
18030 / 6262 / 427
Регистрация: 30.03.2009
Сообщений: 17,206
Записей в блоге: 27
27.02.2011, 16:11 #19
Цитата Сообщение от dipic Посмотреть сообщение
Можете помочь. Я так понимаю у кого то можно взять готовый код? Не поможете??
Если ты задаёшь такой вопрос в теме, где выложено два готовых решения и ссылка, то тебе точно уже ничто не поможет
0
dipic
2 / 2 / 0
Регистрация: 09.12.2010
Сообщений: 45
27.02.2011, 16:17 #20
Я с гугла сразу на 2-ю страничку попал %) невнимателен.

Добавлено через 3 минуты
Evg,
А как можно получить код, если у меня Вижуал Студия 2008-я .. ?
0
Evg
Эксперт CАвтор FAQ
18030 / 6262 / 427
Регистрация: 30.03.2009
Сообщений: 17,206
Записей в блоге: 27
27.02.2011, 17:39 #21
Цитата Сообщение от dipic Посмотреть сообщение
А как можно получить код, если у меня Вижуал Студия 2008-я .. ?
При такой постановке вопроса сразу же ищи вариант под твою студию. У меня нет никакого желания пояснять, как взять исходник и скомпилять его под студией. Тем более потом выяснится, что консольный вариант тебя не устроит и нужен графический. Хотя возможно кто-то и захочет объяснять, но я - пас

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

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

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

Судоку - C++
# include &lt;algorithm&gt; # include &lt;iostream&gt; # include &lt;string.h&gt; # include &lt;stdio.h&gt; # include &lt;iomanip&gt; # include &lt;vector&gt; ...

Судоку - C++
Добрый день! Очень нужна помощь! Нужен код СУДОКУ на С++, задали на курсовую, ничего не получается. В гугле искала, не нашла

проверка судоку - C++
Помогите пожалуйста написать программу , которая проверяет правильность решения судоку. Мне нужно ,чтобы в двумерном массиве в каждой...

почти судоку) - C++
Уже создавала эту тему, но никто не ответил.Может не увидели или не успели.. .Если кто может помочь прошу помогите решить задачу на СИ ...


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

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

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