|
Компьютерный форум OSzone.net » Программирование, базы данных и автоматизация действий » Программирование и базы данных » .NET - *Теория*(VB.NET || C#.net ) Нужен алгоритм для мини - игры |
|
|
.NET - *Теория*(VB.NET || C#.net ) Нужен алгоритм для мини - игры
|
Пользователь Сообщения: 91 |
Профиль | Отправить PM | Цитировать Добрый день!
Игра: есть поле 8 х 8 ячеек(изначально серого цвета), игрок имеет право ходить только буквой "Г" и только в ещё не пройденный квадрат(пройденный квадрат меняет цвет на красный). Допустим игрок сделал n ходов, надо сделать так ,что бы при нажатии на кнопку рядом с игровым полем, компьютер заполнял оставшееся поле с учетом выше перечисленных правил(ходы компьютера сохраняются в файле) или ,если заполнить поле нет возможности, выдавал сообщение об этом. Нужен алгоритм позволяющий заполнять поле после n>=0 ходов игрока.. Может кто нить знает где его можно взять или есть идеи как построить алгоритм?... Заранее благодарю. |
|
Отправлено: 14:36, 15-05-2007 |
DOOMer Сообщения: 3254
|
Профиль | Отправить PM | Цитировать Цитата:
Ну и чего сложного? Массив 8х8, "непохоженное" поле - 0, похоженное - "1". Из текущего положения капм пытается сходить буквой Г, если там единичка - то пытается сходить по-другому, если больше вариантов хода для него нет - то все... |
|
------- Отправлено: 14:44, 15-05-2007 | #2 |
Для отключения данного рекламного блока вам необходимо зарегистрироваться или войти с учетной записью социальной сети. Если же вы забыли свой пароль на форуме, то воспользуйтесь данной ссылкой для восстановления пароля. |
Пользователь Сообщения: 91
|
Профиль | Отправить PM | Цитировать Цитата:
думаю существует какое то математическое решение.. |
|
Отправлено: 14:57, 15-05-2007 | #3 |
Вредитель Сообщения: 460
|
Профиль | Отправить PM | Цитировать Задачи такого типа решаются с помощью рекурсии, и единственный вариант - полный перебор всех вариантов. Насколько я знаю математического решения нет.
|
------- Отправлено: 15:16, 15-05-2007 | #4 |
Пользователь Сообщения: 91
|
Профиль | Отправить PM | Цитировать CyberDaemon
DedAlex ок.. прийду домой попробую написать.. но возникает такой вопрос: Изначально я создаю массив кнопок 8 на 8( поле).. попутно создал массив 8 на 8 типа boolean(true - пройденная ячейка, false - непройденное ячейка).. так вот, как быстрее будет работать программа: если работать с массивом булеан или лучше создать целочисленный массив или вообще использовать свойство уже существующего массива кнопок .tab(mas(i,j) - массив кнопок, mas(i,j).tag=1 - пройденная кнопка-ячейка, mas(i,j).tag=0 - непройденная) ? |
|
Отправлено: 15:33, 15-05-2007 | #5 |
DOOMer Сообщения: 3254
|
Профиль | Отправить PM | Цитировать ssdm
Цитата:
Или игрок должен начать, а компьютер после этого "ходом коня пройти все поле, не попадая дважды в одну и ту-же клетку"? Тогда простор для фантазии в самом деле огромный, и перебором _это_ решать... |
|
------- Отправлено: 16:20, 15-05-2007 | #6 |
Пользователь Сообщения: 91
|
Профиль | Отправить PM | Цитировать Цитата:
|
|
Отправлено: 16:24, 15-05-2007 | #7 |
Пользователь Сообщения: 68
|
Профиль | Отправить PM | Цитировать Цитата:
А при занятых количестве клеток больше допустим 3/4. Можно сделать так: Взять оставшиеся пустые клетки и проверять можно ли туды ходить.А если заняты все клетки то gane over and happy end. Я думаю,если использовать такой вариант алгоритма , его работа существенно ускорится т.к. иначе при большом количестве занятых клеток комп будет впустую проверять варианты ходов. Кстати можно вопрос. Комп просто показует все ходы которые возможно или вы играете с ним. Если идет игра с ним то придется делать еще оценку позицииь. В этом случае перебор вглубь на первых ходах будет ужасно медленным.И почему вы расматриваете только ходы коня, есть же еще много фигур(или это не шахматы) |
|
------- Последний раз редактировалось bezumes, 15-05-2007 в 18:53. Отправлено: 18:46, 15-05-2007 | #8 |
Пользователь Сообщения: 91
|
Профиль | Отправить PM | Цитировать bezumes
это не шахматы.. играю я один.. а комп это что то вроде подсказки.. Цитата:
|
|
Отправлено: 20:25, 15-05-2007 | #9 |
Пользователь Сообщения: 68
|
Профиль | Отправить PM | Цитировать Цитата:
Получается количество ходов=63(8*8-1),и количество уровней дерева.Количество вариантов которые придется перебирать мне и представить сложно Допустим все клетки свободные .фигура находится где то посредине. Смотрим что за ходы у нас есть(8 ходов, если фигура находится с краю поля то меньше).Прросматриваем первый ход.Вновь строим все возможные ходы и так поднимаемся по "дереву" пока или не достигним того что все заполним(кстати все эти текущие ходы надо запоминать)и выведем то что снизу это первые сверху последнии.Если ходы заканчиваются а свободные клетки остаются на уровень вниз и расчет оставшихся ходов. Можно еще сделать чтобы при переходе по дереву на уровень вверх просматривалась ветвь на которой больше всего ходов, т.к. там вероятность того что идем туда выше. Еще можно прикрутить оценку позиции. В центре оценка будет больше, т.к ходов больше, по краям меньше. Певые ходы(2-3) можно сделать случайными(или нельзя?), скорость возрастет на несколько порядков. З.Ы. В любом случае алгоритм решения данной задачи будет жутко медленным, и оптимитизация его затруднена потому что я, допустим не очень то понимаю, где отсечение веток делать. |
|
------- Последний раз редактировалось bezumes, 15-05-2007 в 21:06. Отправлено: 21:00, 15-05-2007 | #10 |
|
Участник сейчас на форуме | Участник вне форума | Автор темы | Сообщение прикреплено |
| |||||
Название темы | Автор | Информация о форуме | Ответов | Последнее сообщение | |
Лучшие игры 2009 года по версии OSZONE.NET. Часть 6 | OSZone News | Новости информационных технологий | 0 | 18-12-2009 23:30 | |
Лучшие игры 2009 года по версии OSZONE.NET. Часть 5 | OSZone News | Новости информационных технологий | 0 | 18-12-2009 23:30 | |
Лучшие игры 2009 года по версии OSZONE.NET. Часть 4 | OSZone News | Новости информационных технологий | 0 | 18-12-2009 21:30 | |
[решено] .NET 3.0 нужен. А нужен ли .NET 2.0 для шаблонного сервера? | LevT | Автоматическая установка Windows 2000/XP/2003 | 7 | 09-07-2007 14:29 | |
Нужен ли E-mail на oszone.net | Seddos | О сайте и форуме | 50 | 06-02-2003 01:58 |
|