Связанный список - это линейная структура данных, состоящая из группы узлов, где каждый узел указывает на следующий узел через указатель. Каждый узел состоит из данных и ссылки (другими словами, ссылки) на следующий узел в последовательности.

Связанные списки - одни из самых простых и распространенных структур данных. Основные преимущества связанного списка перед обычным массивом:

  • Элементы списка могут быть легко вставлены или удалены без перераспределения или реорганизации всей структуры, поскольку элементы данных не должны храниться в памяти непрерывно, а массив должен быть объявлен в исходном коде перед компиляцией и запуском программы.
  • Связанные списки позволяют вставлять и удалять узлы в любой точке списка и могут делать это с постоянным числом операций, если ссылка, предшествующая добавляемой или удаляемой ссылке, сохраняется во время обхода списка.

С другой стороны, простые связанные списки сами по себе не позволяют произвольный доступ к данным или любую форму эффективного индексирования. Таким образом, многие базовые операции, такие как получение последнего узла списка или поиск узла, который содержит заданные данные, или определение места, куда должен быть вставлен новый узел, могут потребовать последовательного сканирования большинства или всех элементов списка. .

В этом посте мы перечислили часто задаваемые вопросы на собеседовании, в которых используется структура данных связанного списка:

  1. Введение в связанные списки
  2. Реализация связанного списка - C, C ++, Java, Python
  3. Связанный список - вставка в хвосте
  4. Статический связанный список
  5. Клонировать связанный список
  6. Удалить связанный список
  7. Вызвать операцию в связанном списке
  8. Вставить узел в его правильную отсортированную позицию в отсортированном связном списке
  9. Переупорядочить связанный список в порядке возрастания (Сортировать связанный список)
  10. Разделить узлы связанного списка на переднюю и заднюю половины
  11. Удалить дубликаты из отсортированного связного списка
  12. Переместить передний узел связного списка перед другим списком
  13. Переместить четные узлы в конец связанного списка в обратном порядке
  14. Разделить связанный список на два списка, каждый из которых содержит чередующиеся элементы
  15. Построить связанный список путем слияния альтернативных узлов двух заданных списков
  16. Объединить два отсортированных связанных списка в один
  17. Эффективное объединение` k` отсортированных связанных списков
  18. Пересечение двух отсортированных связанных списков
  19. Перевернуть связанный список - итерационное решение
  20. Обратный связанный список - рекурсивное решение
  21. Перевернуть каждую группу узлов` k` в связанном списке
  22. Найти k-й узел в конце связанного списка
  23. Объединить альтернативные узлы двух связанных списков в первый список
  24. Объединить два отсортированных связанных списка с их конца
  25. Удалять все« N узлов в связанном списке после пропуска узлов M »
  26. Упорядочить связанный список определенным образом за линейное время
  27. Проверить, является ли связанный список палиндромом
  28. Переместить последний узел в начало связанного списка
  29. Упорядочить связанный список определенным образом
  30. Определить цикл в связанном списке (алгоритм определения цикла Флойда)
  31. Сортировка связанного списка, содержащего 0, 1 и 2, за один проход
  32. Удалить дубликаты из связанного списка за один проход
  33. Переупорядочить связанный список так, чтобы в нем чередовались высокие и низкие значения
  34. Изменить порядок связного списка, отделяя нечетные узлы от четных
  35. Вычислить высоту двоичного дерева с листовыми узлами, образующими круговой двусвязный список
  36. Связанный список XOR - Обзор и реализация на C / C ++
  37. Рекурсивно проверять, является ли связанный список символов палиндромом
  38. Объединить два BST в двусвязный список в отсортированном порядке
  39. Удалить лишние узлы из пути, образованного связным списком
  40. Добавить однозначное число в связанный список, представляющий число
  41. Перевернуть каждую альтернативную группу узлов« k в связанном списке»
  42. Определить, является ли связанный список палиндромом
  43. Перевернуть двусвязный список
  44. Попарно поменять местами соседние узлы связного списка
  45. Свести связанный список
  46. Проверить, является ли связанный список строк палиндромным
  47. Свести многоуровневый связанный список
  48. Постройте сбалансированный по высоте BST из несбалансированного BST
  49. Поменять местами k-й узел с начала на k-й узел с конца в связанном списке
  50. Добавить два связанных списка, не используя лишнего места
  51. Клонировать связанный список со случайными указателями
  52. Обновить случайный указатель для каждого узла связанного списка, чтобы он указывал на максимальный узел
  53. Узлы ссылок присутствуют на каждом уровне двоичного дерева в виде связанного списка
  54. Преобразование тернарного дерева в двусвязный список
  55. Построить BST со сбалансированной высотой из отсортированного двусвязного списка
  56. Объединить на месте два отсортированных связанных списка без изменения ссылок первого списка
  57. Перевернуть указанную часть связного списка
  58. Найти точку пересечения двух связанных списков
  59. Извлечь листья двоичного дерева в двусвязный список
  60. Найдите вертикальную сумму двоичного дерева
  61. Преобразование двоичного дерева в двусвязный список на месте
  62. Найти тройку с заданной суммой в БСТ
  63. Проверить, совпадает ли обход заданных бинарных деревьев по листу
  64. Алгоритм сортировки слиянием для односвязного списка
  65. Сортировать двусвязный список с помощью сортировки слиянием
  66. Реализация стека с использованием связанного списка
  67. Реализация очереди с использованием связанного списка
  68. Преобразование двоичного дерева в двусвязный список по спирали
  69. Преобразование двоичного дерева поиска в минимальную кучу
  70. Преобразование многоуровневого связного списка в односвязный
  71. Распечатать узлы двоичного дерева в вертикальном порядке

Спасибо за чтение.