Minimum Height Trees - Leetcode 310 - Python

  Рет қаралды 23,462

NeetCodeIO

NeetCodeIO

Күн бұрын

Пікірлер: 54
@alexeyfv
@alexeyfv 8 ай бұрын
I was only able to implement a brute force solution, but only 67 out of 71 test cases passed (got time limit exception). 😁Thanks for the video.
@yang5843
@yang5843 8 ай бұрын
Whenever I struggle with daily Leetcode problems, I turn to Neetcode
@shreehari2589
@shreehari2589 8 ай бұрын
Ok
@bhuvan9956
@bhuvan9956 8 ай бұрын
Thanks for this. Please do daily LCs and Contest please.
@sankhadip_roy
@sankhadip_roy 8 ай бұрын
code: class Solution: def findMinHeightTrees(self, n: int, edges: List[List[int]]) -> List[int]: if n==1: return [0] adj = defaultdict(list) for n1,n2 in edges: adj[n1].append(n2) adj[n2].append(n1) edgecount = {} leaves = deque() for s, nei in adj.items(): if len(nei)==1: leaves.append(s) edgecount[s]=len(nei) while leaves: if n
7 ай бұрын
Perhaps slightly simpler (more familiar BFS) impl where we can get rid of the layer traversal technique. At the end of the while loop, all root will have the highest layer value (since they're the last layer) 😃 // Initialize layers with -1, except leaves layers are 0. int max_layer = 0; while (!q.empty()) { int u = q.front(); q.pop(); link[u]--; for (int v : adj[u]) { link[v]--; // Here, one of u's neighbors v just turned into a leaf node after u is removed. if (link[v] == 1 && layers[v] == -1) { layers[v] = layers[u] + 1; max_layer = max(max_layer, layers[v]); q.push(v); } } } vector res; for (int i = 0; i < n; i++) { if (layers[i] == max_layer) { res.push_back(i); } }
@singletmat5172
@singletmat5172 8 ай бұрын
I liked the note about the length and how other languages would calculate the length. With so much python sugar, we forget how a similar code would break in Java or C.
@gary1614
@gary1614 8 ай бұрын
Great video as always! One thing that's worth mentioning is that if n
@KaranBulani
@KaranBulani 8 ай бұрын
was thinking same
@bellxlilies9913
@bellxlilies9913 8 ай бұрын
Yes, if the n
@_N_E_E_R_A_J_
@_N_E_E_R_A_J_ 8 ай бұрын
I solved it using re-rooting. But this "Removing leaf nodes" solution is very amazing. I didn't thought of that. Thank you so much!💖
@3227998
@3227998 3 ай бұрын
Decreasing the number of edges is similar to Kahn's algorithm (topological sort) where indegree of a node is decreased as we traverse the tree.
@harshitdandelia4663
@harshitdandelia4663 2 ай бұрын
But doesn't that only work with Directed graphs?
@skanderbegvictor6487
@skanderbegvictor6487 12 күн бұрын
@@harshitdandelia4663 it should work only with acyclic graphs
@MP-ny3ep
@MP-ny3ep 8 ай бұрын
Thank you so much for the daily. Really helps a lot.
@sallaklamhayyen9876
@sallaklamhayyen9876 2 ай бұрын
great explanation. thank you so much
@MrSkyS-i5v
@MrSkyS-i5v 8 ай бұрын
Missed you buddy 😭
@EduarteBDO
@EduarteBDO 8 ай бұрын
This question was super hard, first I tried solving it with DP with memoization, it gave me TLE on test 70 I think
@chandrikasaha6301
@chandrikasaha6301 3 ай бұрын
Please tell me one thing, why for loop is required here? why only popleft() does not work here
@yang5843
@yang5843 8 ай бұрын
For the edge case, you could check if length of neighbours is 0 or 1, then it will pass the edge case, without having to create an seperate check for the edge case
@tekfoonlim4745
@tekfoonlim4745 8 ай бұрын
Hey Navdeep how are you? I love your leetcode explanations and your solutions! Gives me motivation to do more leetcode
@jand2861
@jand2861 8 ай бұрын
really cool stuff man, thanks for the content
@AmanjotSingh-rj7ox
@AmanjotSingh-rj7ox 3 ай бұрын
Brute : class Solution { public List findMinHeightTrees(int n, int[][] edges) { // Step 1: Initialize the adjacency matrix with large values int[][] matrix = new int[n][n]; for (int[] i : matrix) Arrays.fill(i, 100000); // Large number to indicate no direct path // Step 2: Set the diagonal to 0 and fill in the edges (distance 1 for connected nodes) for (int i = 0; i < n; i++) matrix[i][i] = 0; for (int[] e : edges) { matrix[e[0]][e[1]] = 1; matrix[e[1]][e[0]] = 1; // Undirected graph, so both directions are set } // Step 3: Floyd-Warshall algorithm to calculate shortest paths between all pairs for (int k = 0; k < n; k++) { for (int row = 0; row < n; row++) { for (int col = 0; col < n; col++) { matrix[row][col] = Math.min(matrix[row][col], matrix[row][k] + matrix[k][col]); } } } // Print the resulting distance matrix (for debugging purposes) System.out.print(Arrays.deepToString(matrix)); // Step 4: Find the minimum height trees // For each node, calculate the maximum distance to any other node (its "height") int[] maxDist = new int[n]; int minHeight = Integer.MAX_VALUE; for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { maxDist[i] = Math.max(maxDist[i], matrix[i][j]); } minHeight = Math.min(minHeight, maxDist[i]); } // Step 5: Collect all nodes whose maximum distance is equal to the minimum height List result = new ArrayList(); for (int i = 0; i < n; i++) { if (maxDist[i] == minHeight) { result.add(i); } } return result; } }
@hamirmahal
@hamirmahal 8 ай бұрын
Thanks for putting this up!
@chaitanyasharma6270
@chaitanyasharma6270 8 ай бұрын
Kahn's algorithm as intuition for this question. topsort(remove) where indegree ==1
@Droid261
@Droid261 8 ай бұрын
Thank you, I needed this
@DBagg-zz4ip
@DBagg-zz4ip 8 ай бұрын
Okay. At first I thought it was just BFS from the leaves until you have 2 or 1 left. Lots of tests failed. The whole subtracting edges thing went over my head. Second explanation was easy to get though I haven't tried it yet.
@isitcoffee
@isitcoffee 8 ай бұрын
No need to check if n==1: return[0], we can return [0] after the while loop and it will work fine.
@YuriiPalchynskyi
@YuriiPalchynskyi 8 ай бұрын
Proof why leaf nodes can't be a root of min path. Suppose exist a min path, where leaf node is a root A(leaf) - B(end) , the node A has one neighbor N and this neighbor has to be included into the path A-B , from this we can find a root with smaller path N-B
@phanthe3471
@phanthe3471 8 ай бұрын
it takes me over 15 minutes to be clear the requirement,and until i finished the solution, it takes more than 1 hour.
@pixusru
@pixusru 8 ай бұрын
You’re not supposed to come up with requirements and approach on the spot. You must know every possible problem or pattern by heart, because many do, so you’re looking bad compared to them. Sorry, that’s the game.
@kumarc4853
@kumarc4853 8 ай бұрын
@@pixusru true, the people who post this arent solving this live and for the first time either. So solve as many as you can and spot patterns, recognize general strategies, things to think about when blocked etc
@sophiophile
@sophiophile 7 ай бұрын
​@@pixusru Tell that to interviewers at FAANG companies :(. I have spent a long time preparing for the code portion of an interview w/ one tomorrow (even though I already have another role essentially secured as a backup). There's always going to be the chance that you just don't spot the optimal solution at that time, no matter how prepped you are. For example, most FAANG would not accept the solution coded up here and would require the second approach he described (since it is O(n) time, O(1) memory- while the first is O(n)/O(n))
@erictsend8878
@erictsend8878 Ай бұрын
@@pixusru I agree on the pattern by heart part, but problem by heart? lol. That is not the meaning of DSA and the interview process and if that's your approach to interviews, you are hoping and praying for dumb luck to run into a problem you know during interviews.
@SmoothCode
@SmoothCode 2 ай бұрын
why do we return list(leaves) when n
@srprawinraja4261
@srprawinraja4261 8 ай бұрын
Thanks 😊
@impatientgaming9868
@impatientgaming9868 8 ай бұрын
Good one
@ChiragVithlani
@ChiragVithlani 8 ай бұрын
This problem should be renamed from "Minimum Height Trees" to "Find the root". We can imagine like cutting leaf from all sides equally at same level. What is left is root ( can be two node or one ).
@buckboot
@buckboot 8 ай бұрын
Thanks for this
@omarr993
@omarr993 8 ай бұрын
edging to this rn
@sophiophile
@sophiophile 7 ай бұрын
Can you do a video using Morris traversal?
@sanchitbajaj02
@sanchitbajaj02 8 ай бұрын
Is it ok if after watching an entire video, didn't get the solution considering I only have a basic knowledge of graphs and DFS
@georgerussel
@georgerussel 7 ай бұрын
The brute force solution is still hard to do
@ish90917
@ish90917 8 ай бұрын
Is the time complexity of the code O(n) ?
@amitchoraria5737
@amitchoraria5737 8 ай бұрын
i think yeah should be O(n). but just want someone to confirm
@juanito1410
@juanito1410 8 ай бұрын
The algorithm here is called khan's algorithm and its TC will be O(V+E) where V is the number of vertices/nodes and E for the count of edges.
@deathbombs
@deathbombs 8 ай бұрын
Crazy hard
@chandrikasaha6301
@chandrikasaha6301 3 ай бұрын
Was trying Union join
@bhavasagar977
@bhavasagar977 8 ай бұрын
The second approach feels more intuitive for me...
@jessicakoch2331
@jessicakoch2331 8 ай бұрын
omg i hate graph problems, I hope one day they become less intimidating
@paritoshpandey7998
@paritoshpandey7998 3 ай бұрын
can we say it's the middle of the diameter?
@Silquey
@Silquey 8 ай бұрын
neetcoede
@saarNurf
@saarNurf 2 ай бұрын
One would argue that the goal is to find the median(s) node(s) of the longest path of the graph, and this median(s) would be the root of the MHT. why? because the median will partition the longest path in such a way that the max(left_partition,right_partition) will result in the minimum partition possible, which allows us to minimize the longest path and therefore to achieve the MHT. any thoughts? @NeetCodeIO #neetcode
Spiral Matrix - Microsoft Interview Question - Leetcode 54
16:46
Evaluate Division - Leetcode 399 - Python
17:37
NeetCodeIO
Рет қаралды 34 М.
VIP ACCESS
00:47
Natan por Aí
Рет қаралды 30 МЛН
Beat Ronaldo, Win $1,000,000
22:45
MrBeast
Рет қаралды 158 МЛН
Diameter of a Binary Tree - Leetcode 543 - Python
15:34
NeetCode
Рет қаралды 240 М.
Score After Flipping Matrix - Leetcode 861 - Python
22:30
NeetCodeIO
Рет қаралды 10 М.
Is Graph Bipartite? - Leetcode 785 - Python
11:17
NeetCodeIO
Рет қаралды 19 М.
310. Minimum Height Trees | BFS | Topological Sort | Graphs
24:47
Graph Valid Tree - Leetcode 261 - Python
14:11
NeetCode
Рет қаралды 108 М.
Longest Ideal Subsequence - Leetcode 2370 - Python
28:02
NeetCodeIO
Рет қаралды 12 М.
Distribute Coins in Binary Tree - Leetcode 979 - Python
17:41
NeetCodeIO
Рет қаралды 17 М.