0 / 0 / 0
Регистрация: 26.02.2015
Сообщений: 22

Особый итератор словаря. Медленный итератор

24.04.2015, 05:59. Показов 2175. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Не могу разобраться, как написать итератор. У меня есть словарь, ключи это координаты, а значения это либо ноль, либо единичка (True и False. Как написать итератор, который будет возвращать все возможные комбинации из элементов словаря, причём такие, что нет трех подряд идущих по горизонтали, вертикали, диагонали клеток со значением True(В смысле координат). Я написал некое подобие, где я пербираю вообще все комбинации C из n по k с помощью itertools и отбрасываю лишние, однако это неиэффективно. Можно как-то на этапе поостроения отбрасывать лишние?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.04.2015, 05:59
Ответы с готовыми решениями:

Итератор по словарю
Какие есть способы перебора элементов словаря(dict)? Нужен возврат итератора к первому элементу и инкремент\дикремент к итератору.

Абстрактна фабрика и итератор
Нужно создать класс карты, чтобы представить игральную карту в пирамиде. Создать класс Колода для представления колоды карт в пирамиде....

Регулярные выражения, итератор
str = 'sfsf23sodfsf23sdfhosdj98sljdnfls23' p = re.compile('\d+') z = p.finditer(str) print z #print print

6
2838 / 1647 / 254
Регистрация: 03.12.2007
Сообщений: 4,222
24.04.2015, 17:20
Почему именно словарь, а не список списков или вообще одномерный список? В каком диапазоне координаты? Комбинации - в смысле сочетания? Какое k, заранее известно?
0
0 / 0 / 0
Регистрация: 26.02.2015
Сообщений: 22
26.04.2015, 12:53  [ТС]
Можно и список. Координаты в любом диапазоне потенциально (-inf, +inf), там только ограничения питона, поэтому и словарь, как бы если нет значения по такому-то ключу, значит не существует объекта по таким координатам. Какое к неизвестно. Поэтому лучше, чтобы итератор был ленивый, т.к. получу нужную комбинацию (не буду рассказывать подробности) мне нужно прервать итератор
0
2838 / 1647 / 254
Регистрация: 03.12.2007
Сообщений: 4,222
26.04.2015, 13:58
Если памяти не жалко, то можно сохранять сочетания по k элементов и на их основе генерировать сочетания по k+1.
0
0 / 0 / 0
Регистрация: 26.02.2015
Сообщений: 22
26.04.2015, 14:30  [ТС]
Можете помочь с реализацией?
0
Эксперт NIX
 Аватар для Marinero
2796 / 2039 / 682
Регистрация: 02.03.2015
Сообщений: 6,509
26.04.2015, 15:53
Чтобы не было рядом лежащих итерировать надо через 2 [-k, -k] --> [-k, -k+2][-k+2, -k][-k+2, -k+2]
0
0 / 0 / 0
Регистрация: 26.02.2015
Сообщений: 22
26.04.2015, 15:56  [ТС]
Т.Е. обычный перебор, только брать каждую третью?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.04.2015, 15:56
Помогаю со студенческими работами здесь

Итератор
Напишите итератор, реализующий функцию возврата последовательных чисел геометрической последовательности. Используйте три метода класс...

Создать Итератор
Есть код, необходимо разбить его на класс Iterator и Triangle. Не понимаю как сделать. from itertools import permutations import...

Итератор и последовательность
Чем отличается итератор от последовательности? Нужен грамотный ответ, впринципе я понимаю, но нормально обьяснить не могу.

Создать итератор для класса
Нужна помощь. Дано задание: создать динамическую структуру очередь. Мне нужно осуществить просмотр очереди в главном модуле с помощью...

Бесконечный итератор по нажатой кнопке (PyQt)
Есть кнопка from PyQt5.QtCore import * from PyQt5.QtGui import * from PyQt5.QtWidgets import * import sys import itertools ...


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

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

Новые блоги и статьи
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru