Для студентов МГТУ им. Н.Э.Баумана по предмету ИнформатикаУдаление узла из связанного спискаУдаление узла из связанного списка
2025-01-05СтудИзба

Задача: Удаление узла из связанного списка

Описание

Дан класс Node для представления узла связанного списка и класс LinkedList с методами добавления узлов в конец списка (append) и вывода списка (print_list). Требуется реализовать метод delete_kth_from_end(self, k) класса LinkedList, который удаляет k-й узел с конца списка.
class Node:
"""
Класс узла связанного списка.
Хранит данные и ссылку на следующий узел.
"""
def __init__(self, data):
self.data = data
self.next = None

class LinkedList:
"""
Класс связанного списка.
"""
def __init__(self):
self.head = None

def append(self, data):
"""
Добавляет новый узел с заданными данными в конец списка.
"""
new_node = Node(data) # Создаем новый узел
if not self.head: # Если список пуст
self.head = new_node # Новый узел становится первым
return
current = self.head # Начинаем с первого узла
while current.next: # Идем до последнего узла
current = current.next
current.next = new_node # Добавляем новый узел в конец

def delete_kth_from_end(self, k):
"""
Удаляет k-й узел с конца списка.

Args:
k: Позиция узла для удаления (считая с конца).
"""
pass

def print_list(self):
"""
Печатает все элементы списка в удобном формате.
"""
current = self.head
while current:
print(current.data, end=" -> ")
current = current.next
print("None")

Требования к методу delete_kth_from_end(self, k):
  • Метод принимает один аргумент: k — целое число, представляющее позицию узла для удаления (считая с конца списка).
  • Метод должен удалить k-й узел с конца списка.
  • Метод должен корректно обрабатывать следующие граничные условия:
  • Пустой список (self.head is None).
  • Значение k меньше или равно 0. Список не подвергается изменениям.
  • Значение k больше длины списка. Список не подвергается изменениям.
  • Метод не должен возвращать никаких значений.
  • Асимптотическая сложность метода должна быть O( n ), где n - длина списка. Не используйте дополнительные структуры данных, увеличивающие объем памяти.

Пример использования

# Пример использования
linked_list = LinkedList()
linked_list.append(1)
linked_list.append(2)
linked_list.append(3)
linked_list.append(4)
linked_list.append(5)

# Полученный список:
linked_list.print_list() # Вывод: 1 -> 2 -> 3 -> 4 -> 5 -> None

linked_list.delete_kth_from_end(2) # Удаляем 2-ой узел с конца (4)

# Список после удаления 2-го узла с конца:
linked_list.print_list() # Вывод: 1 -> 2 -> 3 -> 5 -> None

Характеристики решённой задачи

Учебное заведение
Программы
Просмотров
1
Качество
Идеальное компьютерное
Размер
2,43 Kb

Список файлов

pro-10.4.txt
Картинка-подпись
Vladelo

Комментарии

Поделитесь ссылкой:
Цена: 79 руб.
Расширенная гарантия +3 недели гарантии, +10% цены
Рейтинг ждёт первых оценок
0 из 5
Оставьте первую оценку и отзыв!
Поделитесь ссылкой:
Сопутствующие материалы
Вы можете использовать решённую задачу для примера, а также можете ссылаться на неё в своей работе. Авторство принадлежит автору работы, поэтому запрещено копировать текст из этой работы для любой публикации, в том числе в свою задачу в учебном заведении, без правильно оформленной ссылки. Читайте как правильно публиковать ссылки в своей работе.
Свежие статьи
Популярно сейчас
Почему делать на заказ в разы дороже, чем купить готовую учебную работу на СтудИзбе? Наши учебные работы продаются каждый год, тогда как большинство заказов выполняются с нуля. Найдите подходящий учебный материал на СтудИзбе!
Ответы на популярные вопросы
Да! Наши авторы собирают и выкладывают те работы, которые сдаются в Вашем учебном заведении ежегодно и уже проверены преподавателями.
Да! У нас любой человек может выложить любую учебную работу и зарабатывать на её продажах! Но каждый учебный материал публикуется только после тщательной проверки администрацией.
Вернём деньги! А если быть более точными, то автору даётся немного времени на исправление, а если не исправит или выйдет время, то вернём деньги в полном объёме!
Да! На равне с готовыми студенческими работами у нас продаются услуги. Цены на услуги видны сразу, то есть Вам нужно только указать параметры и сразу можно оплачивать.
Отзывы студентов
Ставлю 10/10
Все нравится, очень удобный сайт, помогает в учебе. Кроме этого, можно заработать самому, выставляя готовые учебные материалы на продажу здесь. Рейтинги и отзывы на преподавателей очень помогают сориентироваться в начале нового семестра. Спасибо за такую функцию. Ставлю максимальную оценку.
Лучшая платформа для успешной сдачи сессии
Познакомился со СтудИзбой благодаря своему другу, очень нравится интерфейс, количество доступных файлов, цена, в общем, все прекрасно. Даже сам продаю какие-то свои работы.
Студизба ван лав ❤
Очень офигенный сайт для студентов. Много полезных учебных материалов. Пользуюсь студизбой с октября 2021 года. Серьёзных нареканий нет. Хотелось бы, что бы ввели подписочную модель и сделали материалы дешевле 300 рублей в рамках подписки бесплатными.
Отличный сайт
Лично меня всё устраивает - и покупка, и продажа; и цены, и возможность предпросмотра куска файла, и обилие бесплатных файлов (в подборках по авторам, читай, ВУЗам и факультетам). Есть определённые баги, но всё решаемо, да и администраторы реагируют в течение суток.
Маленький отзыв о большом помощнике!
Студизба спасает в те моменты, когда сроки горят, а работ накопилось достаточно. Довольно удобный сайт с простой навигацией и огромным количеством материалов.
Студ. Изба как крупнейший сборник работ для студентов
Тут дофига бывает всего полезного. Печально, что бывают предметы по которым даже одного бесплатного решения нет, но это скорее вопрос к студентам. В остальном всё здорово.
Спасательный островок
Если уже не успеваешь разобраться или застрял на каком-то задание поможет тебе быстро и недорого решить твою проблему.
Всё и так отлично
Всё очень удобно. Особенно круто, что есть система бонусов и можно выводить остатки денег. Очень много качественных бесплатных файлов.
Отзыв о системе "Студизба"
Отличная платформа для распространения работ, востребованных студентами. Хорошо налаженная и качественная работа сайта, огромная база заданий и аудитория.
Отличный помощник
Отличный сайт с кучей полезных файлов, позволяющий найти много методичек / учебников / отзывов о вузах и преподователях.
Отлично помогает студентам в любой момент для решения трудных и незамедлительных задач
Хотелось бы больше конкретной информации о преподавателях. А так в принципе хороший сайт, всегда им пользуюсь и ни разу не было желания прекратить. Хороший сайт для помощи студентам, удобный и приятный интерфейс. Из недостатков можно выделить только отсутствия небольшого количества файлов.
Спасибо за шикарный сайт
Великолепный сайт на котором студент за не большие деньги может найти помощь с дз, проектами курсовыми, лабораторными, а также узнать отзывы на преподавателей и бесплатно скачать пособия.
Популярные преподаватели
Добавляйте материалы
и зарабатывайте!
Продажи идут автоматически
6376
Авторов
на СтудИзбе
309
Средний доход
с одного платного файла
Обучение Подробнее