|
75 / 9 / 1
Регистрация: 07.06.2016
Сообщений: 132
|
||||||
Как определить бесконечный список?04.09.2020, 11:58. Показов 6487. Ответов 22
Метки нет (Все метки)
Добрый день. Есть такая ситуация: в результате работы кода, появляются бесконечно вложенные друг в друга списки (указывающие сами на себя). Например,
0
|
||||||
| 04.09.2020, 11:58 | |
|
Ответы с готовыми решениями:
22
Бесконечный список
|
|
75 / 9 / 1
Регистрация: 07.06.2016
Сообщений: 132
|
|
| 04.09.2020, 12:03 [ТС] | |
|
0
|
|
| 04.09.2020, 12:07 | |
|
Не по теме: NatiF, я ошибся.
0
|
|
|
8840 / 4492 / 1864
Регистрация: 27.03.2020
Сообщений: 7,312
|
|||||||
| 04.09.2020, 13:06 | |||||||
|
NatiF,
Сам же и ответил -
Добавлено через 5 минут А если грубо, то через ~
0
|
|||||||
|
|
||
| 04.09.2020, 13:27 | ||
|
Ни у кого из программистов (кроме школьников) никогда не возникало такой проблемы как у тебя. Делай выводы.
0
|
||
|
75 / 9 / 1
Регистрация: 07.06.2016
Сообщений: 132
|
||
| 04.09.2020, 13:46 [ТС] | ||
|
0
|
||
|
|
|||||||
| 04.09.2020, 13:52 | |||||||
|
И они тоже не знали про то, как в Python делать копию данных вместо ссылки. Добавлено через 4 минуты Вот этот вот код
0
|
|||||||
|
8840 / 4492 / 1864
Регистрация: 27.03.2020
Сообщений: 7,312
|
||||||
| 04.09.2020, 14:00 | ||||||
|
Если степень вложенности, то можно так (желательно максимальную длину вложенного списка не больше 2)
Добавлено через 6 минут Более подробно по распаковке: https://www.pvsm.ru/python/328552
1
|
||||||
|
75 / 9 / 1
Регистрация: 07.06.2016
Сообщений: 132
|
|||||||
| 04.09.2020, 14:58 [ТС] | |||||||
0
|
|||||||
|
295 / 108 / 57
Регистрация: 07.12.2016
Сообщений: 209
|
||||||
| 04.09.2020, 15:28 | ||||||
|
NatiF, может как-то так подойдет?
0
|
||||||
|
Супер-модератор
|
|||||||||||
| 04.09.2020, 18:27 | |||||||||||
Сообщение было отмечено NatiF как решение
Решение
Вот способ распознания циклической (бесконечной) структуры:
140275051180616 <- адр его нулевого элемента совпадает с ним самим - цикл ! 140275051173064 <- здесь 140275051173128 <- все хорошо Добавлено через 2 минуты Кстати, можно и без лишних скобок создать циклическую структуру:
1
|
|||||||||||
| 04.09.2020, 18:56 | |
|
NatiF, Сами подумайте. Список это объект питона занимающий некоторое количество оперативной памяти. При каждом вложении Вы увеличиваете количество занимаемой памяти. Количество памяти в компьютере ограничено. Если Вы будете производить бесконечное вложение, то количество занимаемой памяти будет постоянно увеличиваться, пока не произойдет переполнение, и компьютер перестанет работать и предварительно сообщит об ошибке.
Поэтому, что бы не доводить до сбоя программы, питон обнаружив зацикленность преобразует бесконечное вложение в такую форму [[...]]. Что является предупреждением, что такой код не допустим и нужно его изменить, что бы не было зацикленности. Поэтому Вам нужно не жаловаться на [[...]] , а описать Вашу задачу, и попросить помочь избавиться от зацикливания. Добавлено через 4 минуты NatiF, Опишите условие Вашей задачи и Ваш код ее решения. Тогда народ поможет его исправить, что бы не было зацикливания. Добавлено через 5 минут NatiF, Скорее всего Вам понадобится код с рекурсией и с выходом из рекурсии по некоторому условию, для того , что бы не произошло переполнение. А может нужно решать не через рекурсию, а просто циклом, все зависит от условия задачи, которое Вы не описали.
0
|
|
|
|
||
| 04.09.2020, 20:09 | ||
|
Но не суть. Catstail, предложил сравнивать id (который в Python возвращает нечто аналогичное адресу) вкладываемого элемента и id контейнера. Это позволит выявить момент, когда происходит вставка в список того же самого списка, чтобы вызвать вручную в этом месте raise Exception или же заменять его на копию. Добавлено через 1 минуту P.S. А самопостроитель это кто? Кодогенератор? И в чем конкретный смысл вашей задачи?
0
|
||
|
75 / 9 / 1
Регистрация: 07.06.2016
Сообщений: 132
|
|||
| 05.09.2020, 01:21 [ТС] | |||
|
Добавлено через 12 минут
0
|
|||
|
|
||
| 05.09.2020, 12:59 | ||
|
В Python, например, есть такая экзотика как диалект Лиспа - Hylang, который умеет генерить AST Python.
0
|
||
|
75 / 9 / 1
Регистрация: 07.06.2016
Сообщений: 132
|
||
| 05.09.2020, 13:09 [ТС] | ||
|
0
|
||
|
|
|
| 05.09.2020, 13:14 | |
|
0
|
|
|
|
|||
| 05.09.2020, 20:13 | |||
|
Ну или иной подход - считать, что такие списки позволены, но тогда не жаловаться, что "с этой дрянью работать невозможно".
1
|
|||
| 05.09.2020, 20:13 | |
|
Помогаю со студенческими работами здесь
20
Бесконечный список совершенных чисел
Бесконечный список съел один елемент
Составить бесконечный список последовательностей биномиальных коэффициентов Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
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-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|