JavaAlgorithms/DataStructures/Lists
2021-10-16 16:43:51 +03:00
..
CircleLinkedList.java Fix Circular linked list (#2598) 2021-10-16 16:31:24 +03:00
CountSinglyLinkedListRecursion.java Formatted with Google Java Formatter 2021-04-09 14:19:34 +00:00
CursorLinkedList.java Add what is Cursor Linked List (#2407) 2021-10-08 19:38:08 +03:00
detect_and_create_loop.jav Detect a loop in linked list (#2346) 2021-10-01 08:39:38 +03:00
DoublyLinkedList.java Formatted with Google Java Formatter 2020-10-24 10:23:28 +00:00
Merge_K_SortedLinkedlist.java Formatted with Google Java Formatter 2020-10-24 10:23:28 +00:00
MergeSortedArrayList.java Formatted with Google Java Formatter 2020-10-24 10:23:28 +00:00
MergeSortedSinglyLinkedList.java Formatted with Google Java Formatter 2020-10-24 10:23:28 +00:00
README.md Add README for lists (#2421) 2021-10-08 19:47:36 +03:00
RemoveDuplicateNodes.java Fix package declarations (#2576) 2021-10-16 16:43:51 +03:00
SearchSinglyLinkedListRecursion.java Formatted with Google Java Formatter 2020-10-24 10:23:28 +00:00
SinglyLinkedList.java update SinglyLinkedList (#2058) 2020-12-01 09:33:06 +08:00

Linked List

Description

LinkedList is a data structure in which data is stored in a linear manner. It usually contains a data field and a link to the memory location of the next mode.

Structure

class LinkedList<E>{
    E value;
    LinkedList next;
}

The next variable points to the next node in the data structure and value stores the data. Any number of nodes can be linked in this manner. The structure will be:

Properties

  1. Linked list does not provide indexing like an array. For accessing a node at position p , θ(p) nodes need to be accessed.
  2. Main advantage of linked list is addition and removal of nodes near the end and beginning of lists. It can be done just by updating the link (O(1) time)
  3. Unlike an array, its size is not predefined. So any number of nodes can be appended.

File descriptions:

  1. CircleLinkedList.java : A circular linked list where next pointer of last node points to first nide of linked list.
  2. SinglyLinkedList.java : The classic case of single links.
  3. CountSinglyLinkedListRecursion.java: Recursively counts the size of a list.
  4. detect_and_create_loop.java : Detect a loop in linked list
  5. DoublyLinkedList.java : A modification of singly linked list which has a prev pointer to point to the previous node.
  6. Merge_K_SortedLinkedlist.java : Merges K sorted linked list with mergesort (mergesort is also the most efficient sorting algorithm for linked list).