Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sydrawat01/algorithms
🗂 Leetcode and ADT
https://github.com/sydrawat01/algorithms
algorithms java leetcode leetcode-solutions
Last synced: 20 days ago
JSON representation
🗂 Leetcode and ADT
- Host: GitHub
- URL: https://github.com/sydrawat01/algorithms
- Owner: sydrawat01
- License: mit
- Created: 2022-06-02T17:41:53.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2022-08-30T22:14:27.000Z (over 2 years ago)
- Last Synced: 2024-10-28T11:34:38.228Z (2 months ago)
- Topics: algorithms, java, leetcode, leetcode-solutions
- Language: Java
- Homepage:
- Size: 129 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Algorithms [![CircleCI](https://dl.circleci.com/status-badge/img/gh/sydrawat01/algorithms/tree/master.svg?style=svg)](https://dl.circleci.com/status-badge/redirect/gh/sydrawat01/algorithms/tree/master)
Basic algorithms, Data Structures and Graphs. Also includes LeetCode problems and their solutions.
## Elementary Sorting Techniques
- [Bubble Sort](./src/main/java/ADT/Sort/BubbleSort)
- [Insertion Sort](./src/main/java/ADT/Sort/InsertionSort)
- [Selection Sort](./src/main/java/ADT/Sort/SelectionSort)
- [Merge Sort](./src/main/java/ADT/Sort/MergeSort) [WIP]
- [Shell Sort](./src/main/java/ADT/Sort/ShellSort)
- [Quick Sort](./src/main/java/ADT/Sort/QuickSort)
- [Heap Sort](./src/main/java/ADT/Sort/HeapSort) [WIP]## Linear Non-Sorting Techniques
- [Knuth Shuffle](./src/main/java/ADT/Sort/Shuffling/KnuthShuffle.java)
- [Quick Select](./src/main/java/ADT/Sort/Shuffling/QuickSelect.java) [WIP]## Abstract Data Types
- [Binary Search](./src/main/java/ADT/BinarySearch/BinarySearch.java) [Iterative & Recursive]
- [Binary Insertion Sort](./src/main/java/ADT/BinaryInsertion/BinaryInsertionSort.java)
- [ArrayList Duplicates](./src/main/java/ADT/Duplicates/ArrayListDuplicates.java)
- [LinkedList](./src/main/java/ADT/LinkedList)
- [Doubly Linked List](./src/main/java/ADT/DList/DList.java)
- [Stack](./src/main/java/ADT/Stack)
- [Queue](./src/main/java/ADT/Queue)
- [Quick Find](./src/main/java/ADT/UnionFind/QuickFindUF.java)
- [Quick Union](./src/main/java/ADT/UnionFind/QuickUnionUF.java)
- [Weighted Quick Union](./src/main/java/ADT/UnionFind/WeightedQuickUnionUF.java)
- [Weighted Quick Union with Path Compression](./src/main/java/ADT/UnionFind/WeightedQuickUnionPCUF.java)
- [Binary Search Tree](./src/main/java/ADT/BST/BinarySearchTree.java)## APIs
- [Linked List](./src/main/java/ADT/API/LinkedList/LinkedList.java)
- [Doubly Linked List](./src/main/java/ADT/API/DoublyLinkedList)
- [Stack](./src/main/java/ADT/API/Stack)
- [Queue](./src/main/java/ADT/API/Queue)
- [Queue as Doubly-linked list](./src/main/java/ADT/API/DoublyLinkedList/DLLQueue.java)
- [Bag](./src/main/java/ADT/API/Bag)## Graphs
- [Depth First Search](./src/main/java/Graphs/DFS.java)
- [DFS Paths](./src/main/java/Graphs/DFSPaths.java)
- [Breadth First Search](./src/main/java/Graphs/BFSPaths.java)
- [Undirected Graph](./src/main/java/Graphs/Graph.java) [Basic]
- [Directed Graphs](./src/main/java/Graphs/digraph)
- [Minimum Spanning Tree](./src/main/java/Graphs/MST)
- [Shortest Path](./src/main/java/Graphs/ShortestPath)## Leetcode Solutions
Below are some LeetCode problems that are solved using Java. These are divided into easy, medium and hard problems for
better classification.Long way to go!
### Easy Java
- [x] [9. Palindrome Number](https://leetcode.com/problems/palindrome-number/) : [Solution](./src/main/java/leetcode/solutions/solution9)
- [x] [35. Search Insert Position](https://leetcode.com/problems/search-insert-position/) : [Solution](./src/main/java/leetcode/solutions/solution35)
- [x] [58. Length of Last Word](https://leetcode.com/problems/length-of-last-word/) : [Solution](./src/main/java/leetcode/solutions/solution58)
- [x] [83. Remove Duplicates from a Sorted List](https://leetcode.com/problems/remove-duplicates-from-sorted-list/) : [Solution](./src/main/java/leetcode/solutions/solution83)
- [x] [206. Reverse Linked List](https://leetcode.com/problems/reverse-linked-list/) : [Solution](./src/main/java/leetcode/solutions/solution206)
- [x] [234. Palindrome Linked List](https://leetcode.com/problems/palindrome-linked-list/): [Solution](./src/main/java/leetcode/solutions/solution234)
- [x] [287. Find the Duplicate Number](https://leetcode.com/problems/find-the-duplicate-number/) : [Solution](./src/main/java/leetcode/solutions/solution287)
- [x] [442. Find All Duplicates in an Array](https://leetcode.com/problems/find-all-duplicates-in-an-array/) : [Solution](./src/main/java/leetcode/solutions/solution442)
- [x] [1342. Number of Steps to Reduce a Number to Zero](https://leetcode.com/problems/number-of-steps-to-reduce-a-number-to-zero/) : [Solution](./src/main/java/leetcode/solutions/solution1342)
- [x] [1356. Sort Integers by The Number of 1 Bits](https://leetcode.com/problems/sort-integers-by-the-number-of-1-bits/) : [Solution](./src/main/java/leetcode/solutions/solution1356)
- [x] [1365. How Many Numbers Are Smaller Than the Current Number](https://leetcode.com/problems/how-many-numbers-are-smaller-than-the-current-number/) : [Solution](./src/main/java/leetcode/solutions/solution1365)
- [x] [2062. Count Vowel Substrings of a String](https://leetcode.com/problems/count-vowel-substrings-of-a-string/) : [Solution](./src/main/java/leetcode/solutions/solution2062)## Unit Tests
Unit tests have been implemented for 100% code coverage. Algorithms that have not yet been implemented, or have bugs, have not been implemented yet.
Here's the link to the unit tests: [Unit Tests](/src/test/java)
## Author
[Siddharth Rawat](https://sydrawat.netlify.app)
## [License](./LICENSE)