Skip to content

Latest commit

 

History

History
56 lines (47 loc) · 16 KB

README.md

File metadata and controls

56 lines (47 loc) · 16 KB

LeetCode Solutions

Find video link at my YouTube channel
Or from the Sheet 1 of this Google Sheet

Made with Python Made with Java Made with C++

# Title Solution Code Time Space Difficulty Tags Video
0001 2 Sum problem Check all the combinations by looping Map, if it’s complement (target - element) and exists then return the indices of the current element and the complement. C++ Java Python O(n) O(1) Easy Hash Table Heap 📺
0011 Container With Most Water Two pointer approach from left and right side. Increment the left pointer if height is less than right otherwise decrement the right pointer. If current holding capacity is more than previous update. Python O(n) O(1) Medium Array Two pointer
0021 Merge Two Sorted Lists Algo The strategy here uses a temporary dummy node as the start of the result list. The pointer Tail always points to the last node in the result list, so appending new nodes is easy. The dummy node gives the tail something to point to initially when the result list is empty. C++ O(m+n) O(1) Easy Linked List 📺
0021 Merge Two Sorted Lists The strategy here uses a temporary dummy node as the start of the result list. The pointer Tail always points to the last node in the result list, so appending new nodes is easy.The dummy node gives the tail something to point to initially when the result list is empty.This dummy node is efficient, since it is only temporary, and it is allocated in the stack.The loop proceeds, removing one node from either ‘a’ or ‘b’, and adding it to the tail Java O(n) O(1) Easy Linked List 📺
0027 Remove Element Two pointers for counting valid nos and swapping Java Python O(n) O(1) Easy Array Two Pointers 📺
0044 Wildcard Matching Use bottom-up approach, when '?' detected copy value from upper diagonal cell and when '*' detected copy value from previous coloumn same row or previous row same coloumn Python O(n*n) O(n*n) Hard DP on Regex problem
0045 Jump Game II newEnd = max(newEnd, i+nums[i]) C++ O(n) O(1) Hard Array Greedy 📺
0053 Maximum Subarray Parse array and save the best solution at each step Java Python O(n) O(1) Easy Array Dynamic Programming 📺
0055 Jump Game Iterate from last index and check if we can reach there from current index or not Python O(n) O(1) Medium Array Greedy 📺
0062 Unique Paths (Total no of unique paths in m x n matrix) As the first element in each row will always be 1, so maintaining one row is enough to reach bottom-right corner of the grid Java Python O(n) O(1) Medium Array Dynamic Programming
0070 Climbing Stairs steps[n]=steps[n-1]+steps[n-2]. C++ Python O(n) O(1) Easy Dynamic Programming 📺
0072 Edit Distance minDis(i,j)=min(minDis(i-1,j),minDis(i,j-1),minDis(i-1,j-1))+1; Java O(m*n) O(m*n) Hard String Dynamic programming
0073 Set Matrix Zeroes Use the first cell of every row and column as a flag. This flag would determine whether a row or column has been set to zero. C++ Python O(m*n) O(1) Medium Array 📺
0075 Sort an array of 0’s 1’s 2’s without using extra space or sorting algo the logic is to count total number of 0's, 1's and 2's int the list and starting from beginning first append total 0's then total 1's and then 2's Java Python O(n) O(1) Medium Array 📺
0100 Same Tree Check isSame(node.left) and isSame(root.right) Java O(n) O(h) Easy Tree Depth-first-Search 📺
0100 Same Tree Check isSame(node.left) and isSame(root.right) Java Python O(n) O(h) Easy Tree Depth-first-Search 📺
0101 Symmetric Tree Check if left.left==right.right and left.right==right.left Java Python O(n) O(h) Easy Tree Depth-first-Search Breadth-first-Search 📺
0104 Maximum Depth of Binary Tree Depth = 1 + Max(depth of left, depth of right) Java O(n) O(h) Easy Tree Depth-first-Search 📺
0121 Best time to buy and sell stock Minimize Cost price and Maximise Profit , if the current value minus the minimum is the new maximum profit Java Python O(n) O(1) Easy Array Dynamic Programming 📺
0142 Linked List Cycle II Floyd’s Cycle detection algorithm Java O(n) O(1) Medium Linked List Two pointers
0198 House Robber Keep track of max money by figuring out whether to loot the current house or not Python O(n) O(1) Easy Dynamic Programming 📺
0200 Number of islands Merging adjacent lands, and the merging is done recursively Java O(n∗m) O(1) Medium Depth-First Search Breadth-First Search 📺
0268 Missing Number Assuming that XOR is a constant-time operation, this algorithm does constant work on nn iterations, so the runtime is overall linear C++ Java O(n) O(1) Easy Array Math BitManipulation
0283 Move Zeroes Two pointers for counting valid nos and swapping Java O(n) O(1) Easy Array Two Pointers 📺
0287 Find duplicate in array of N+1 numbers Find the cycle using slow and fast pointer Java O(n) O(1) Medium Array Two Pointers
0300 Longest Increasing Subsequence when next element in array is greater than previous element, dp[i]=maximum(dp[j]+1,dp[i]) Java O(n*m) O(n) Medium Binary Search Dynamic Programming
0451 Sort Characters By Frequency LeetCode Github Java Python O(n) O(n) Medium Hash Table Heap
0509 Fibonacci Number Storing the value of two previous number and updating them Java O(n) O(1) Easy Array 📺
0647 Palindromic Substrings Extend from center, 2 function call for odd and even palindromes Java Python O(n^2) O(1) Medium String Dynamic Programming 📺
0695 Max Area of Island Apply DFS on the Gird by exploring every square connected to it 4-directionally, total number of squares explored will be the area of that connected shape. C++ O(R∗C) O(R∗C) Medium Depth-First-Search
0876 Middle of the Linked List Find the length of given linked list and then traverse from root till one less than half of linked list length and print the next node to current node Java O(n) O(1) Easy Linked List
0983 Minimum Cost For Tickets Here dp(i) is the cost to travel from day days[i] to the end of the plan. if days[j] < days[i] + 1 then j1=j. if days[j] < days[i] + 7 then j=j7. if days[j] < days[i] + 30 then j=j30 . dp(i)=min(dp(j1)+costs[0],dp(j7)+costs[1],dp(j30)+costs[2]) Java O(n) O(n) Medium Dynamic Programming 📺
1347 Minimum Number of Steps to Make Two Strings Anagram Add 1 for char in s and remove 1 for char in t Java Python O(n+m) O(1) Medium Hash Table Heap 📺
1352 Product of the Last K Numbers Add new element to list by multiplying it with previous number and return arr[n-1]/arr[n-k-1] Python O(1) O(1) Medium Array Design 📺

Format

0000 Ques name Algo Java O() O() Easy Category 📺
0000 Ques name Algo Java O() O() Easy Category 📺

Built with love