С Новым годом! Форум программистов, компьютерный форум, киберфорум
Python
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
0 / 0 / 0
Регистрация: 26.02.2015
Сообщений: 22

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

24.04.2015, 05:59. Показов 2171. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Новый 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 Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru