Не знаю, как решить эту «ошибку памяти»

В настоящее время я получаю память всякий раз, когда запускаю свой код. Вот часть моего кода, которая вызывает проблему. Строка clear_nodes.append(i+(grid_size*4)) - это та, которая дает ошибку памяти, и я не уверен, как от нее избавиться. Спасибо

blocked_rows = []
for num in range(grid_size, 2*grid_size):
    blocked_rows.append(num)
    blocked_rows.append(num+(grid_size*2))
    blocked_rows.append(num+2*(grid_size*2))
    blocked_rows.append(num+3*(grid_size*2))
    blocked_rows.append(num+4*(grid_size*2))
    blocked_rows.sort()
    clear_nodes = []
    for i in blocked_rows:
        if i == (grid_size*2)-1:
            clear_nodes.append(i)
        if i == (grid_size*3):
            clear_nodes.append(i)
        for i in clear_nodes:
            clear_nodes.append(i+(grid_size*4))
            #clear_nodes.append(i+(grid_size*8))
        for i in clear_nodes:
            if i < (grid_size * grid_size):
                all_blocked.append(i)
for i in clear_nodes: clear_nodes.append(...) — это бесконечный цикл — вы добавляете элементы в список, который перебираете. Если вы хотите перебрать только те элементы, которые уже присутствовали, вам нужно использовать копию списка: for i in clear_nodes[:]:.
jasonharper 02.04.2019 15:32

Это кажется сложностью N * N * N из-за трех вложенных «для»; Я думаю, вы должны реорганизовать свой код

Don 02.04.2019 15:32

Вы должны опубликовать точное сообщение об ошибке, которое выдает ваш код, это даст нам много подсказок.

Hoog 02.04.2019 15:34

Спасибо Джейсон :) отличная помощь

JJH562 02.04.2019 15:34

Более элегантный способ получить то, что вы хотите, с помощью цикла: clear_nodes.extend(i + grid_size * 4 for i in clear_nodes).

Karl Knechtel 02.04.2019 15:44
Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
1
5
46
0

Другие вопросы по теме