My notes on Data structure and Algos in golang implementation and python
data:image/s3,"s3://crabby-images/be948/be948631c87de85803e620a95fd35007df7187bf" alt=""
My notes on Data structure and Algos in golang implementation and python
Arrays
Advantages of array
- Reading and writing is O(1)
Disadvantages of array
- Insertion and deletion is O(n)
- Arrays are not dynamic
- If you need to store an extra element, you would have to create a new array and copy all the elements over. O(n)
List Slicing in python
- [start:stop:step]
- Reverse a list
list[::-1]
LinkedList
- Linked lists are great for problems that require arbitrary insertion.
- Dynamic arrays allow inserting at arbitrary locations, but they require you to move all elements after your insertion point.
- Doubly LinkedLists don’t have this problem: you can insert or delete elements in a linked list in constant time, as long as you know where the element is.
- The downside is that they don’t allow constant time access: to find the ith element, you need to traverse i