3 / 3 / 0
Регистрация: 20.07.2018
Сообщений: 249
|
||||||||||||||||
1 | ||||||||||||||||
Крисс-кросс, этюды для программистов03.12.2022, 21:24. Показов 1631. Ответов 33
Здравствуйте, пытаюсь решить задачу из книги Уэзерелла Чарльза "Этюды для программистов". Задача крисс - кросс. Нужно по заданному списку слов построить сетку. В местах пересечения слова имеют одинаковые буквы. Я написал вот такую программу:
main.cpp:
0
|
03.12.2022, 21:24 | |
Ответы с готовыми решениями:
33
Кроссворд крисс-кросс в делфи Задание по книге "Этюды для программистов" Реализация Игры "Жизнь" из книги Уэзерелл Ч. "Этюды для программистов" Ищу программистов Cocos2d-x для разработки игр, Ищу программистов C++ Кросс-компиляция для raspberry |
3 / 3 / 0
Регистрация: 20.07.2018
Сообщений: 249
|
|
06.12.2022, 21:05 [ТС] | 21 |
Тоже просто совпало) Но сейчас как раз хочу добавить условие исключения соприкасания
0
|
3 / 3 / 0
Регистрация: 20.07.2018
Сообщений: 249
|
|
06.12.2022, 22:03 [ТС] | 22 |
Этот результат пока наилучшее, что у меня получилось
1
|
3718 / 2647 / 761
Регистрация: 29.06.2020
Сообщений: 9,800
|
||||||
06.12.2022, 22:49 | 23 | |||||
Так же создал новую версию класса Сетки, добавил в метод проверки фильтр на соприкасание.
Вот так вот получилось. Телескопу толком места не осталось. Хотя если ограничить поле размерами, то он бы упаковался к слову cosmonaut. Хотя еще можно изменить порядок выбора мест не по добавлению слов, а по расстоянию к центру кроссворда (его первого слова) Код
c p ogalaxy l a o n universe i t p t s a meteorite cosmonaut l e e s c o p e Последний код, со скудными комментариями, без оптимизаций, и излишними контейнерами. C++17
Добавлено через 1 минуту Точно, в коде нет проверок на размеры сетки. То есть пока сетка только "резиновая".
0
|
3 / 3 / 0
Регистрация: 20.07.2018
Сообщений: 249
|
|
06.12.2022, 23:18 [ТС] | 24 |
У меня есть какой то странный момент: если у меня не осталось не использованных слов, то я вывожу полученную сетку. Первая такая сетка - та что выше, а все последующие имеют странную особенность: слово universe стирается. Ладно стирается, так оно убирается не полностью, а счетчик слов указывает, что оно все еще в сетке. Чудеса
0
|
3 / 3 / 0
Регистрация: 20.07.2018
Сообщений: 249
|
|
06.12.2022, 23:20 [ТС] | 25 |
А все, проблема решена, я не до конца проверял соприкасание между словами)
0
|
3718 / 2647 / 761
Регистрация: 29.06.2020
Сообщений: 9,800
|
|
06.12.2022, 23:25 | 26 |
_lUserl_, а вы позади слова проверяете соприкасание?
Я вот пропустил, добавил уже, но засорять не хочу своими правками. В моем посте #23, слово galaxy прилепилось к другому
0
|
3 / 3 / 0
Регистрация: 20.07.2018
Сообщений: 249
|
|
06.12.2022, 23:26 [ТС] | 27 |
Теперь надо бы решить проблему со связанностью и компактность решетки. Можно ли как то вычислить максимальный размер сетки имея только набор слов?
0
|
3718 / 2647 / 761
Регистрация: 29.06.2020
Сообщений: 9,800
|
|
06.12.2022, 23:26 | 28 |
_lUserl_, в общем поздравляю, за упорность вашу, все таки доделали (хоть так)
1
|
3 / 3 / 0
Регистрация: 20.07.2018
Сообщений: 249
|
|
06.12.2022, 23:28 [ТС] | 29 |
Да, и как раз из за этого у меня и стиралась вселенная)
Добавлено через 42 секунды Спасибо вам тоже, вы подали много хороших идей!
0
|
3718 / 2647 / 761
Регистрация: 29.06.2020
Сообщений: 9,800
|
|
06.12.2022, 23:28 | 30 |
Даже не знаю что на это ответить. На глаз, оно такое не нужно.
У меня такой проблемы нет
0
|
3 / 3 / 0
Регистрация: 20.07.2018
Сообщений: 249
|
|
06.12.2022, 23:30 [ТС] | 31 |
Просто изначально я создаю матрицу фиксированного заведомо большего размера, хотелось бы как нибудь этого избежать
0
|
3718 / 2647 / 761
Регистрация: 29.06.2020
Сообщений: 9,800
|
|
06.12.2022, 23:39 | 32 |
Ну это зависит от набора слов.
И как я уже писал, начинать выбирать буквы для вставки, начиная с выбранного центра кроссворда (например центра первого слова.). А связность, это особый случай. То есть при переборе мест вставки, искать все варианты, и выбирать тот, где наибольше пересечений с другими словами. Так и делается, создается размер ожидаемого кроссворда, составили сетку. Не нравится, увеличили/уменьшили размеры поля. И заново составляем сетку. Например в моем коде добавить ограничение сетки довольно просто, так же как и метод ее расширения, с сохранением текущего расположения слов. Сужать же более сложно, для этого придется удалять слова и связи, но так же возможно. Лучше этим не заморачиваться, если вы заранее об этом не подумали. Добавлено через 4 минуты Edit : добавлено несколько важных правок в пост!
0
|
3 / 3 / 0
Регистрация: 20.07.2018
Сообщений: 249
|
|
06.12.2022, 23:41 [ТС] | 33 |
Хорошо, я попробую сделать еще что нибудь. Большое спасибо за помощь, это, наверное, одна из самых трудоемких задач из тех, что мне приходилось решать
Добавлено через 1 минуту В книге написано так: Качество схем крисс-кросса пропорционально их «связанности», т. е., чем теснее в среднем слова переплетены с соседями, тем интереснее головоломка. Связанность можно измерять по-разному: как отношение площади схемы к площади наименьшего объемлющего прямоугольника; как среднее число пересечений на слово; как среднее число пересечений на букву; как минимальное число пересечений на слово. При генерации головоломок крисс-кросс для массовых изданий использовалась коммерческая программа, но головоломки получались неинтересные — слишком длинные и извилистые. Когда ваша программа заработает, позаботьтесь об увеличении связанности. Буду пытаться решить эту задачу
1
|
3718 / 2647 / 761
Регистрация: 29.06.2020
Сообщений: 9,800
|
|
07.12.2022, 00:24 | 34 |
Попытался скомпоновать плотнее, пока только очередностью выбора потенциальных мест вставки (от своего центра, относительного, (0,0)).
Также слова из вектора, берутся до тех пор, пока хотя бы одно слово на каждом проходе, было вставлено. То-есть, если не получилось вставить, оставляю слово на след. круг. Если ни одного слова не было вставлено из всего вектора, прерываю цикл. Более-менее смотрится, но еще есть над чем подумать. Хотя я пока наигрался Код
Add word "universe" - success Add word "colonist" - success Add word "planet" - success Add word "space" - success Add word "galaxy" - fail Add word "meteorite" - success Add word "cosmonaut" - fail Add word "telescope" - success Add word "comet" - success Add word "eclipse" - success Add word "gravity" - fail Add word "observatory" - success Add word "galaxy" - success Add word "cosmonaut" - success Add word "gravity" - success space o m c planet observatory o t m universe i o t s r g t i a telescope eclipse a o x s y m o n gravity u t
0
|
07.12.2022, 00:24 | |
07.12.2022, 00:24 | |
Помогаю со студенческими работами здесь
34
Макрос для кросс журнала Кросс компиляция для Raspberry Pi 3 EntityFramework для кросс-платформенного приложения Кросс-сборка ядра для powerpc Кросс-компиляция из Windows для Linux, MacOS В поисках идеального кросс-платформенного GUI для C# Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |