L45. K-th Smallest/Largest Element in BST

  Рет қаралды 197,003

take U forward

take U forward

Күн бұрын

Пікірлер
@takeUforward
@takeUforward 3 жыл бұрын
In largest, we can traverse right node left and then apply the same logic.. You can also contribute an article for this video: takeuforward.org/contribute/help-us-grow-takeuforward/ Will be continuing with this setup, as youtube tends to push videos with human appearance!!
@solaris413
@solaris413 3 жыл бұрын
any plan of hiring interns for ur site and what will be the requirements
@ananthalakshmi
@ananthalakshmi 7 ай бұрын
@takeUforward Thank you so much anna🤩🤩🤩🤩🤩🤩..... keep doing more and more videos anna.... For finding smallest using #InorderMorrisTraversal (left, root, right) :- code🔥🔥🔥🔥🔥🔥:- int kthSmallest(TreeNode* root, int k) { TreeNode* cur = root; int ans; int count =0; while(cur != nullptr){ if(cur -> left == nullptr){ count += 1; if(count == k){ ans= cur -> val; } cur = cur -> right; } else{ TreeNode* prev = cur -> left; while(prev -> right != nullptr && prev -> right != cur){ prev = prev -> right; } if(prev -> right== nullptr){ prev -> right = cur; cur = cur -> left; } else{ count += 1; prev -> right = nullptr; if(count == k){ ans =cur -> val; } cur = cur -> right; } } } return ans; } for finding largest using #reversalInorderMorrisTraversal (right root left) :- code🔥🔥🔥🔥🔥🔥:- int kthLargest(Node* root, int k) { Node* cur = root; int ans; int count =0; while(cur != nullptr){ if(cur -> right == nullptr){ count += 1; if(count == k){ ans= cur -> data; } cur = cur -> left; } else{ Node* prev = cur -> right; while(prev -> left != nullptr && prev -> left != cur){ prev = prev -> left; } if(prev -> left== nullptr){ prev -> left = cur; cur = cur -> right; } else{ count += 1; prev -> left = nullptr; if(count == k){ ans =cur -> data; } cur = cur -> left; } } } return ans; }
@deanwinchester8691
@deanwinchester8691 3 жыл бұрын
for kth largest we can do a reverse inorder kind of thing: RIGHT ROOT LEFT with the counter logic
@SouravGhosh-yb1ee
@SouravGhosh-yb1ee 2 жыл бұрын
Yep
@lokeshrajput2458
@lokeshrajput2458 2 жыл бұрын
Yeah
@kinshuk1743
@kinshuk1743 2 жыл бұрын
Han bete
@nikhilmeena8585
@nikhilmeena8585 2 жыл бұрын
We can even find n-k+1 smallest for kth largest
@parthsalat
@parthsalat 2 жыл бұрын
Nice dp
@GauravKumar-dw2ml
@GauravKumar-dw2ml 2 жыл бұрын
For kth largest just do the reverse in-order , and print the kth element. Bcoz this will lead to decreasing order.
@secondarypemail7181
@secondarypemail7181 2 жыл бұрын
This is the first solution that comes in the mind
@mohdhammadsiddiqui7598
@mohdhammadsiddiqui7598 2 жыл бұрын
Just a small observation In the kth largest problem if we take reverse inorder than the elements are sorted in descending fashion, so we can directly get kth largest element
@yagniktalaviya2146
@yagniktalaviya2146 2 жыл бұрын
sahi hai!!
@amanali9501
@amanali9501 2 жыл бұрын
correct ✅
@peacefullife2071
@peacefullife2071 3 ай бұрын
Of course ! but the optimal solution as he said is not to use any extra space. That's why n-k logic comes.
@parikshitsinghrathore6130
@parikshitsinghrathore6130 2 жыл бұрын
we can also do this by doing inorder traversal (this will make the vector in sorted format) and then finding the kth smallest no. in it. time complexity will be O(n) + O(n)
@akshaychavan5511
@akshaychavan5511 7 ай бұрын
For the kth largest question, we don't even need to make the adjustment as (n-k)th smallest element. We can simply reverse the order of traversal as - Right - Root - Left
@ChayK11
@ChayK11 5 ай бұрын
so its post order right?
@wttc4
@wttc4 5 ай бұрын
@@ChayK11 no, postorder traversal is: left->right->root
@vaishnavigour5777
@vaishnavigour5777 2 жыл бұрын
for Kth largest it should be (n-k+1)th smallest
@parthsalat
@parthsalat 2 жыл бұрын
Exactly! I was thinking about this
@viveknagar4537
@viveknagar4537 Жыл бұрын
@@parthsalat right
@UdayKumar-tm1fb
@UdayKumar-tm1fb 10 күн бұрын
Nooo
@stith_pragya
@stith_pragya 6 ай бұрын
Understood.............Thank You So Much for this wonderful video.....🙏🏻🙏🏻🙏🏻🙏🏻🙏🏻🙏🏻
@kushagraahire1871
@kushagraahire1871 Жыл бұрын
JAVA Solution for Smallest Kth: - class Solution { private int count = 0; private int result = 0; public int kthSmallest(TreeNode root, int k) { traverse(root, k); return result; } private void traverse(TreeNode node, int k) { if (node == null) { return; } traverse(node.left, k); count++; if (count == k) { result = node.val; return; } traverse(node.right, k); } } JAVA Solution for Largest Kth: - class Solution { int ans = 0; int count = 0; public int kthLargest(Node root,int k) { traversal(root,k); return ans; } public void traversal(Node root, int k){ if(root == null) return; traversal(root.right,k); count++; if(count == k){ ans = root.data; return; } traversal(root.left,k); } }
@kushagrakulshrestha2966
@kushagrakulshrestha2966 Ай бұрын
Nice name bro
@budhadityachatterjee6270
@budhadityachatterjee6270 3 жыл бұрын
Diwali pe DP Series aa rha hain kya ?
@abcsumits
@abcsumits 2 жыл бұрын
why not we visit directly right first and left after while treversing for k th max. :) it will be done in one treversal
@aayushprajapati347
@aayushprajapati347 3 жыл бұрын
I think Kth largest element can be done in single traversal. By using reverse inorder traversal i.e.(Right-Node-Left) .Then we can easily figure out kth largest element in single traversal. Just require few modification in code: int kthLargest(TreeNode* root, int k) { stack st; TreeNode* node = root; int cnt = 0; while(true) { if(node != NULL) { st.push(node); node = node->right; } else { if(st.empty() == true) break; node = st.top(); st.pop(); cnt++; if(cnt == k) return node->val; node = node->left; } } return -1; }
@takeUforward
@takeUforward 3 жыл бұрын
Yeah..
@विशालकुमार-छ7त
@विशालकुमार-छ7त 3 жыл бұрын
Don't write like this inside if condition st.empty()==true You can just write if( st.empty() )
@aayushprajapati347
@aayushprajapati347 3 жыл бұрын
@@विशालकुमार-छ7त Actually it is not my code it is striver's code i just modify it for the largest
@विशालकुमार-छ7त
@विशालकुमार-छ7त 3 жыл бұрын
@@aayushprajapati347 oo...sorry
@kaushikkumarbora
@kaushikkumarbora 2 жыл бұрын
aeee red coder
@shantanugupta-oz1dx
@shantanugupta-oz1dx 5 ай бұрын
Thank you for the simple explanation
@xavier6955
@xavier6955 3 жыл бұрын
Man, I was stuck with this problem yesterday coz I didn't get what I have to find from all the tutorials online. Striver explained it in 2 mins.🔥
@geekaffairs6475
@geekaffairs6475 3 жыл бұрын
I can't believe you are in I.T
@xavier6955
@xavier6955 3 жыл бұрын
@@geekaffairs6475 I am not in IT, I am the IT.
@utkarshverma2604
@utkarshverma2604 3 жыл бұрын
@@geekaffairs6475 samw bro ye banda har jagah h
@divyanshusingh2396
@divyanshusingh2396 2 жыл бұрын
If we use inorder then there will be no need of sorting… because inorder of bst is already sorted
@mridulsarma9022
@mridulsarma9022 3 жыл бұрын
Bhaiya it may be n+1-k th element..as for if we have 4 nodes then 2nd element from last will be 4+1-2 th i.e 3rd node.thats why I am saying about this confusion
@aditisneh6420
@aditisneh6420 3 жыл бұрын
ya same . It should be n+1-k
@jayanth1191
@jayanth1191 2 жыл бұрын
Yes
@ishankbansal9239
@ishankbansal9239 3 жыл бұрын
OP Video Quality and Setup🔥 Using Morris Inorder Traversal TC - O(N), SC - O(1) class Solution { public: int kthSmallest(TreeNode* root, int k) { int count = 0; int ans; TreeNode* curr = root; while(curr){ if(curr->left == NULL){ count++; if(count == k){ ans = curr->val; } curr = curr->right; } else{ TreeNode* prev = curr->left; while(prev->right && prev->right != curr){ prev = prev->right; } if(prev->right == NULL){ prev->right = curr; curr = curr->left; } else{ count++; prev->right = NULL; if(count == k){ ans = curr->val; } curr = curr->right; } } } return ans; } };
@Avinashkumar-km2cl
@Avinashkumar-km2cl 2 жыл бұрын
Bro, I have written the same code as yours but I am having a doubt. why we are not breaking the loop..? we got the required solution. I tried this but it showed an error. if possible then please clear my doubt. @take U forward Code: class Solution { public: int kthSmallest(TreeNode* root, int k) { int i=0; int ans=0; TreeNode*curr; while(root) { if(!root->left) { i++; if(i==k) { ans= root->val; break; } root=root->right; } else { curr=root->left; while(curr->right && curr->right!=root) curr=curr->right; if(curr->right==root) { curr->right=NULL; i++; if(i==k) { ans= root->val; break; } root=root->right; } else { curr->right=root; root=root->left; } } } return ans; } };
@mayankkumar6067
@mayankkumar6067 2 жыл бұрын
@@Avinashkumar-km2cl Hey , i am also trying to break out of loop but getting error, if you got an answer then please help
@factfactorial632
@factfactorial632 2 жыл бұрын
@@Avinashkumar-km2cl because in morris traversal you did create threads and now you are not breaking it
@akshitsangwan_
@akshitsangwan_ 2 жыл бұрын
@@factfactorial632 So we have to traverse the whole tree and can't break the loop, even if we got the answer at the very start!??
@mukib_khan_
@mukib_khan_ 2 жыл бұрын
@@akshitsangwan_ got the answer anyone?
@ahustler110
@ahustler110 25 күн бұрын
but why will we sort?? inorder of bst is already sorted array in incresing order
@AbhishekPandey-dj2eo
@AbhishekPandey-dj2eo 11 ай бұрын
Keep doing this GOOD WORK
@sagarkakkar4150
@sagarkakkar4150 Жыл бұрын
kth element can be found out in O(N) using quick sort
@mayanksardana3179
@mayanksardana3179 Жыл бұрын
quick sort is nlogn bro
@sagarkakkar4150
@sagarkakkar4150 Жыл бұрын
We just have to run quicksort partition function one time to find kth element
@sagarkakkar4150
@sagarkakkar4150 Жыл бұрын
Not one time but a few times It's called quick select
@ankittjindal
@ankittjindal 3 жыл бұрын
Ab yhi request h bhaiya..... recursion, backtracking,dp k v ase hii series alg alg dsa k upr lekr aaiye!! plzzz bhaiyaaa ❤️❤️❤️🥺🥺🙏🙏🙏
@mridulsarma9022
@mridulsarma9022 3 жыл бұрын
Check the playlists..I hope you will get all of those.
@ankittjindal
@ankittjindal 3 жыл бұрын
@@mridulsarma9022 nii bro bat wo nii h bhaiyaaa ne toh usme syd sde sheet ka sb video explain qsn sb ka dala hua h n ... .
@ankittjindal
@ankittjindal 3 жыл бұрын
@@mridulsarma9022 toh wo beginner recursion ye sb me kse dkh skta h koi v ...hm ye bol rhe ki in sb ka dsa ka v ase hii playlist bnaye ...jse ki aapne graph,tree ka bnya h ye bol rhe h hm . bro..... Wse wo sb playlist ksa h qsns sb ka maine nii dkha h pura...kyuki meko abhi wo sb utna nii ata bhaii mere!!
@pranshumehta3228
@pranshumehta3228 2 жыл бұрын
If we do simple recursive inorder traversal then time complexity should be O(k) because we don't need to go further after getting kth smallest Is that correct ?
@dianafarhat9479
@dianafarhat9479 2 жыл бұрын
Yes, but at most K is equal to n (e.g. k=n) . So, the worst case scenario is O(n).
@imPriyansh77
@imPriyansh77 9 ай бұрын
worst case scenario would be O(N)
@arjunkurariya2235
@arjunkurariya2235 3 жыл бұрын
Best Series ever seen❤️❤️. Is CP necessary for CODING ROUND..??? PLS ANSWER 🙏🙏🙏
@shivangisrivastava1158
@shivangisrivastava1158 3 жыл бұрын
Thodi mehnat lag gyi Morris implement krne me, but golden content!
@Stickman-rz9nu
@Stickman-rz9nu 8 ай бұрын
can you please provide the morris traversal solution ? i'm getting stack overflow error 🥹🥹
@rakhshanahmad8057
@rakhshanahmad8057 9 ай бұрын
Great explanation. Those last approaches are great.
@izumi7754
@izumi7754 8 ай бұрын
you said u have provided the code in the description but it isnt there, this is a very common occurence when i look at descrptions i never find the codes, am i looking at the wrong place or is he just not attaching the code
@anishaa3298
@anishaa3298 8 ай бұрын
you are welcome: class Solution { int count=0; int result; public int kthSmallest(TreeNode root, int k) { if (root==null) { return 0; } inOrderTraversal(root,k); return result; } public void inOrderTraversal(TreeNode root, int k) { if (root==null) { return ; } inOrderTraversal(root.left,k); count++; if (count==k) { result =root.val; return; } inOrderTraversal(root.right,k); } }
@rushidesai2836
@rushidesai2836 5 ай бұрын
He's providing quality content for free, and still you are complaining for a small mistake?
@prasannamalatesha3887
@prasannamalatesha3887 Жыл бұрын
Great explanation bro. Perfectly explained all the possible solutions for this problem
@ANANDKUMAR-hd8mj
@ANANDKUMAR-hd8mj 12 күн бұрын
nice concept
@AlokSingh-qj3hf
@AlokSingh-qj3hf 7 күн бұрын
class Solution(object): def __init__(self): self.c = 0 self.r = 0 def kthSmallest(self, root, k): """ :type root: TreeNode :type k: int :rtype: int """ def inor(k,c,root): if root==None: return inor(k,c,root.left) self.c+=1 if k==self.c: self.r=root.val return inor(k,c,root.right) inor(k,self.c,root) return self.r
@abhijitroy1958
@abhijitroy1958 2 жыл бұрын
when you were explaining the brut ,i accidentally coded the optimal by using morries xd
@aryanchaurasia1081
@aryanchaurasia1081 Жыл бұрын
For kth largest we can do right root left traversal
@tanveer.shaikh
@tanveer.shaikh 2 жыл бұрын
I did not understand why you need to sort the elements, if we do inorder traversal we could do it in o(n),
@alliswellbrochill9937
@alliswellbrochill9937 2 жыл бұрын
same doubt
@tech_wizard9315
@tech_wizard9315 3 жыл бұрын
Is your tree series enough for DSA beginners for Tech interviews of companies like Microsoft , linkedin etc?
@tech_wizard9315
@tech_wizard9315 3 жыл бұрын
@Anna English thanks for letting me know
@vedantsharma5876
@vedantsharma5876 2 жыл бұрын
@Strawberry and Strings
@alesblaze4745
@alesblaze4745 2 жыл бұрын
thanks mate! this was really challenging & fun solving, tried to implement it using Moris Traversal without revising and took a while to implement but was able to implement it successsfully!
@parthsalat
@parthsalat 2 жыл бұрын
Nice dp...Daffodils, isn't it?
@sparshsharma3150
@sparshsharma3150 3 жыл бұрын
Striver's video explanation --- mind blown Striver's video explanation with face cam ---- mind blown ultra pro max 😂😂
@mayankbisht1277
@mayankbisht1277 3 ай бұрын
For largest why not do [Right,Node,Left] ?
@sushantbhosale5792
@sushantbhosale5792 3 жыл бұрын
Striver bhaiya aur kitne videos baki he playlist ke when it will be completed??
@Usurperhk
@Usurperhk 3 жыл бұрын
Bhaiya this is the best evolution of your videos. Left side knowledge right side legend. It's f***king awesome bhaiya. 🙂🙂🙂
@ChetanSingh-zp4ct
@ChetanSingh-zp4ct 2 жыл бұрын
LeetCode 230: class Solution { public: int count = 0; int ans; void inorder(TreeNode* root, int k){ if(!root)return; inorder(root->left,k); if(++count==k){ ans = root->val; return; } inorder(root->right,k); } int kthSmallest(TreeNode* root, int k) { inorder(root,k); return ans; } };
@herculean6748
@herculean6748 2 жыл бұрын
Thanks bro!
@VishalGupta-xw2rp
@VishalGupta-xw2rp 2 жыл бұрын
We can also add condition like.... To increase the count value only when there's some value there and not NULL like if(root) if (++count==k)
@yativishnoi5110
@yativishnoi5110 2 жыл бұрын
@@VishalGupta-xw2rp But we already checked for the root, then root can't be null. So no need to check for it.
@only_for_fun1234r
@only_for_fun1234r Жыл бұрын
If (ans!=-1) return ans; will it save something?
@akshayteja2864
@akshayteja2864 6 ай бұрын
C++ Solution class Solution { public: void helper(TreeNode *root,int &k,int &count,int &ans) { if(root==NULL) return; helper(root->left,k,count,ans); count++; if(count==k) ans=root->val; helper(root->right,k,count,ans); } int kthSmallest(TreeNode* root, int k) { int count=0,ans; helper(root,k,count,ans); return ans; } };
@abhinavkumar6584
@abhinavkumar6584 2 жыл бұрын
shouldn't kth largest should be n-k+1 ??? Anyone?
@JEAnandkumar
@JEAnandkumar 2 жыл бұрын
One correction: k th largest element = (n-k+1)th smallest element
@parthsalat
@parthsalat 2 жыл бұрын
Exactly! I was thinking about this
@dingo_5998
@dingo_5998 2 жыл бұрын
Thank you bhaiya Meet me in G.😎😎😎😎
@codeman3828
@codeman3828 8 ай бұрын
Understood. Thanks
@sahil_bagde
@sahil_bagde 2 ай бұрын
C++ Code : class Solution { public: vectorans; void inorder(TreeNode* root){ if(root == NULL ) return; inorder(root->left); ans.push_back(root->val); inorder(root->right); } int kthSmallest(TreeNode* root, int k) { inorder(root); return ans[k-1]; } };
@reddysasikiran315
@reddysasikiran315 2 ай бұрын
what if duplicate elements are there
@KnowledgeofEverything
@KnowledgeofEverything 3 жыл бұрын
New setup is good .... But I don't think it matters much .... For me your content matters more and it's great
@AnandSingh-zm5cm
@AnandSingh-zm5cm 3 жыл бұрын
Why we need to sort?Inorder always gave sorted elements
@imPriyansh77
@imPriyansh77 9 ай бұрын
we need to sort only if we're implementing preorder, postorder or level order.
@aryansinha1818
@aryansinha1818 2 жыл бұрын
06:40 Largest
@sakshamsengar9798
@sakshamsengar9798 2 жыл бұрын
shoudn't it be for kth largest we need n-k+1th smallest?????
@imPriyansh77
@imPriyansh77 9 ай бұрын
yeah!!
@anshulgoel1940
@anshulgoel1940 Жыл бұрын
Can we do R N L for Kth largest using morris? I just tried a psuedo code seems possible.
@isheep9025
@isheep9025 Жыл бұрын
morris traversal for kth largest and "dec" vector in program stores decreasing order of values /** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: int kthSmallest(TreeNode* root, int k) { int cnt=0; TreeNode * curr=root; int ans; vector dec; while(curr!=NULL) { if(curr->right==NULL) { cnt++; if(cnt==k) { ans=curr->val; } dec.push_back(curr->val); curr=curr->left; } else{ TreeNode * temp=curr->right; while(temp->left!=NULL && temp->left!=curr) temp=temp->left; if(temp->left==NULL){ temp->left=curr; curr=curr->right;} else{ temp->left=NULL; cnt++; if(cnt==k) { ans=curr->val; } dec.push_back(curr->val); curr=curr->left; } } } for(int ele:dec) cout
@naman_goyal
@naman_goyal 3 жыл бұрын
Ab maza aayega na bidu💝👍
@hitenrana4775
@hitenrana4775 2 жыл бұрын
One of my friend's got rejection in amazon with morris traversal approach. How can you do this in only logN complexity? This was asked in amazon interview and the approach doesn't make sense. It was written that we can store a count of left subtree nodes while generating the tree. Generation will take o(n) itself then how can it be logN.
@ideepakpandey
@ideepakpandey 2 жыл бұрын
complexity will be o(n) not logn, space complexity will be o(1)
@hitenrana4775
@hitenrana4775 2 жыл бұрын
@@ideepakpandey thats what i said read the comment again
@Rajat_maurya
@Rajat_maurya 2 жыл бұрын
GFG article hai Method 2: Augmented Tree Data Structure (O(h) Time Complexity and O(h) auxiliary space) The idea is to maintain the rank(count) of each node. We can keep track of elements in the left subtree of every node while building the tree. Since we need the K-th smallest element, we can maintain the number of elements of the left subtree in every node. Assume that the root is having ‘lCount’ nodes in its left subtree. If K = lCount + 1, root is K-th node. If K < lCount + 1, we will continue our search (recursion) for the Kth smallest element in the left subtree of root. If K > lCount + 1, we continue our search in the right subtree for the (K - lCount - 1)-th smallest element. Note that we need the count of elements in the left subtree only.
@vishious14
@vishious14 Жыл бұрын
List result; public int kthSmallest(TreeNode root, int k) { result = new ArrayList(); inorder(root,k); return result.get(result.size()-1); } private void inorder(TreeNode root,int k){ if(root==null) return; inorder(root.left,k); if(result.size()==k) return; result.add(root.val); inorder(root.right,k); }
@ankitkr09
@ankitkr09 3 жыл бұрын
Agar ek din pehle upload kr deta bhai toh mera amazon clear ho jata..
@takeUforward
@takeUforward 3 жыл бұрын
Haan kal hi kia tha upload
@nandinisugandhi748
@nandinisugandhi748 2 жыл бұрын
What was asked to you.
@MadhavGupta-fi2tu
@MadhavGupta-fi2tu Жыл бұрын
class Solution { public: void inorder(TreeNode* root,int &c,int &k,int &ans){ if(!root)return; inorder(root->left,c,k,ans); c++; if(c==k){ans=root->val; return;} inorder(root->right,c,k,ans); } int kthSmallest(TreeNode* root, int k) { int c=0; int ans; inorder(root,c,k,ans); return ans; } };
@DeepakKumar-mn8yi
@DeepakKumar-mn8yi 11 ай бұрын
we can add if(c>k) return; before root->right;
@shubamgoswami
@shubamgoswami 3 жыл бұрын
striver video is like the latest iPhone top notch but with facecam It is like u get air pods and fast charger in the box with the latest apple cloth.
@pvenkatesh3690
@pvenkatesh3690 Ай бұрын
It's looking kth largest approach is wrong. it should be Kth largest = (N-K) + 1 smallest element
@geekaffairs6475
@geekaffairs6475 3 жыл бұрын
Amazing explanation.
@VIRAJBHOSLE
@VIRAJBHOSLE Жыл бұрын
need to improve this video. not very clear
@santoshkumarroy5070
@santoshkumarroy5070 2 жыл бұрын
explanation on point . loved it bhaiya
@lavanyaprakashjampana933
@lavanyaprakashjampana933 2 жыл бұрын
we love your content and we love you...🖤
@adityapandey23
@adityapandey23 3 ай бұрын
Understood
@shouvikdatta6831
@shouvikdatta6831 3 жыл бұрын
Man, after DP, make a series on stack & queue..
@mohitsingh7793
@mohitsingh7793 2 жыл бұрын
kth largest=(n-k+1)th smallest element.
@KartikeyTT
@KartikeyTT 4 ай бұрын
tysm sir
@vaalarivan_p
@vaalarivan_p Жыл бұрын
4:25
@UECAshutoshKumar
@UECAshutoshKumar Жыл бұрын
Thank you sir
@ShubhanshuG007
@ShubhanshuG007 Жыл бұрын
Using Morris Traversal class Solution { public: Node* inorder(Node* root, int &K){ Node* curr = root; while(curr != NULL){ if(curr->left == NULL){ K--; if(K==0) return curr; curr = curr->right; } else{ Node* prev = curr->left; while(prev->right != NULL && prev->right != curr){ prev = prev->right; } if(prev->right == NULL){ prev->right = curr; curr = curr->left; } else{ prev->right = NULL; K--; if(K==0) return curr; curr = curr->right; } } } return NULL; } // Return the Kth smallest element in the given BST int KthSmallestElement(Node *root, int K) { // add code here. Node* res = inorder(root, K); if( res != NULL) return res->data; return -1; } };
@divyanshjain7999
@divyanshjain7999 7 ай бұрын
it isnt giving error on leetcode?
@sankalpietechtips
@sankalpietechtips Жыл бұрын
Thanks bro, you did good
@harshitjaiswal9439
@harshitjaiswal9439 10 ай бұрын
understood.
@Girish415
@Girish415 3 жыл бұрын
Thank you
@chiragbansod8252
@chiragbansod8252 9 ай бұрын
understood
@Anonymous-uj3jx
@Anonymous-uj3jx 2 жыл бұрын
Understood thanks :)
@saurabhgautam2697
@saurabhgautam2697 2 жыл бұрын
Can anyone Please ,explain to me why is it showing run-time error ,I m trying to do inorder morris traversal class Solution { public: int kthSmallest(TreeNode* root, int k) { int freq=0; TreeNode* ans; if(root==NULL)return 0; TreeNode* curr=root; while(curr!=NULL){ if(curr->left==NULL){ freq++; if(freq==k){ return curr->val; break; } curr=curr->right; } else{ TreeNode* temp=curr->left; while(temp->right!=NULL && temp->right!=curr) temp=temp->right; if(temp->right==NULL){ temp->right=curr; curr=curr->left; } else{ //temp->right=NULL; freq++; if(freq==k){ return curr->val; } temp->right=NULL; curr=curr->right; } } } return -1; } };
@adityan5302
@adityan5302 2 жыл бұрын
else{ //temp->right=NULL; freq++; if(freq==k){ return curr->val; } temp->right=NULL; curr=curr->right; Here you are trying to edit the BST, maybe that's the issue
@saarthaksharma9555
@saarthaksharma9555 Жыл бұрын
You have to return integer answer but you are returning 'node' so just put the condition that when freq==k, ans=cur->val; and at the end return ans;
@saarthaksharma9555
@saarthaksharma9555 Жыл бұрын
and don't apply the break statement as it will give stack overflow error because of the morris threading
@ThoNguyenuc-pz3yr
@ThoNguyenuc-pz3yr Жыл бұрын
@@saarthaksharma9555 yeah, if we use break or return the construct of binary tree will change and cause to overflow, we have to run until the curr is null
@aditya-st1sv
@aditya-st1sv 3 жыл бұрын
#Striveronfire 🔥🔥🔥
@shantipriya370
@shantipriya370 11 ай бұрын
us..
@saumyakarnwal7551
@saumyakarnwal7551 2 жыл бұрын
what if we perform an in order traversal as it will be automatically sorted void helper(TreeNode* root,vector & v,int k){ if(v.size()==k||root==NULL) return; helper(root->left,v,k); v.push_back(root->val); helper(root->right,v,k); } int kthSmallest(TreeNode* root, int k) { vector v; helper(root,v,k); return v[k-1]; } the complexity is still O(min (k,n)) wont that will be more efficient
@mdshaqlain3252
@mdshaqlain3252 2 жыл бұрын
time complexity will be O(N), since we have to go to every node if we are storing in vector
@mehulmorker258
@mehulmorker258 2 жыл бұрын
C++ code link opens Javacode and Java code link opens C++ code. Edit That Bro 😇
@roopeshn3301
@roopeshn3301 2 жыл бұрын
Understood
@sundarbsr4275
@sundarbsr4275 Жыл бұрын
understand ❤
@suvanshmahajan5902
@suvanshmahajan5902 2 жыл бұрын
"us"
@anubhavverma7193
@anubhavverma7193 3 ай бұрын
int inorderTraversal(TreeNode* root, int k) { TreeNode* curr = root; int cnt=0; while(curr) { if(curr->left==NULL) { cnt++; if(k==cnt) return curr->val; curr=curr->right; } else { TreeNode* prev = curr->left; while(prev->right && prev->right!=curr) { prev = prev->right; } if(prev->right==NULL) { prev->right=curr; curr=curr->left; } else { prev->right=NULL; cnt++; if(k==cnt) return curr->val; curr=curr->right; } } } return -1; } int kthSmallest(TreeNode* root, int k) { if(root==NULL) return -1; return inorderTraversal(root , k); } for this code im getting the following error AddressSanitizer:DEADLYSIGNAL ================================================================= ==22==ERROR: AddressSanitizer: stack-overflow on address 0x7ffea2a00ff8 (pc 0x564fc93607d9 bp 0x7ffea2a01010 sp 0x7ffea2a01000 T0) #0 0x564fc93607d9 in __TreeNodeUtils__::freeTreeHelper(TreeNode*) (solution+0x1a87d9) #1 0x564fc9360800 in __TreeNodeUtils__::freeTreeHelper(TreeNode*) (solution+0x1a8800) #2 0x564fc9360800 in __TreeNodeUtils__::freeTreeHelper(TreeNode*) (solution+0x1a8800) #3 0x564fc93607dd in __TreeNodeUtils__::freeTreeHelper(TreeNode*) (solution+0x1a87dd) #4 0x564fc9360800 in __TreeNodeUtils__::freeTreeHelper(TreeNode*) (solution+0x1a8800) #5 0x564fc9360800 in __TreeNodeUtils__::freeTreeHelper(TreeNode*) (solution+0x1a8800) #6 0x564fc93607dd in __TreeNodeUtils__::freeTreeHelper(TreeNode*) (solution+0x1a87dd)
@shashankojha3452
@shashankojha3452 3 жыл бұрын
That makes sense
@purushottam108
@purushottam108 5 ай бұрын
finally after this video, your face is in the video, video is booring without your face and newer version of you make thing more clear then older version of striver.
@NikhilGupta-zo5jh
@NikhilGupta-zo5jh 2 жыл бұрын
understood
@adityaprakash1172
@adityaprakash1172 Жыл бұрын
I am getting runtime error in Leetcode everytime while doing through Morris Traversal int kthSmallest(TreeNode* root, int k) { if(root == NULL) return -1; int cnt=0; TreeNode* curr = root; TreeNode* temp; while(curr){ if(curr -> left == NULL){ temp = curr; cnt++; curr = curr -> right; } else{ TreeNode* pred = curr -> left; while(pred -> right && pred -> right != curr) pred = pred -> right; if(pred -> right == NULL){ pred -> right = curr; curr = curr -> left; } else{ pred -> right = NULL; temp = curr; cnt++; curr = curr -> right; } } if(cnt == k){ return temp -> val; } } return -1; } Can anyone correct it?
@zanies6288
@zanies6288 Жыл бұрын
class Solution { public: int kthSmallest(TreeNode* root, int k) { int count = 0; int ans; TreeNode* curr = root; while(curr){ if(curr->left == NULL){ count++; if(count == k){ ans = curr->val; } curr = curr->right; } else{ TreeNode* prev = curr->left; while(prev->right && prev->right != curr){ prev = prev->right; } if(prev->right == NULL){ prev->right = curr; curr = curr->left; } else{ count++; prev->right = NULL; if(count == k){ ans = curr->val; } curr = curr->right; } } } return ans; } };
@divyanshjain7999
@divyanshjain7999 7 ай бұрын
@@zanies6288 then this is not O(K) it becomes O(N)
@momilijaz271
@momilijaz271 2 жыл бұрын
done!
@KaushikSharma-c3q
@KaushikSharma-c3q Жыл бұрын
.....................
@preetikushwaha8734
@preetikushwaha8734 3 жыл бұрын
Finally 🔥
@ajayypalsingh
@ajayypalsingh 2 жыл бұрын
💚
@p38_amankuldeep75
@p38_amankuldeep75 2 жыл бұрын
💝💙💝
@piyushacharya7696
@piyushacharya7696 2 жыл бұрын
reach++
@Girish415
@Girish415 3 жыл бұрын
Coolm
@SHASHANKRUSTAGII
@SHASHANKRUSTAGII 3 жыл бұрын
im the 400 like
@JEAnandkumar
@JEAnandkumar 2 жыл бұрын
One correction: k th largest element = (n-k+1)th smallest element
@parthsalat
@parthsalat 2 жыл бұрын
Exactly! I was thinking about this
@ayushkushwaha171
@ayushkushwaha171 Жыл бұрын
correct!
@khushududeja2183
@khushududeja2183 5 ай бұрын
right. i was thinking the same.
@sibiranganath
@sibiranganath Ай бұрын
Understood
@abhinanda7049
@abhinanda7049 7 ай бұрын
understood
@VikasGupta-ok9lh
@VikasGupta-ok9lh Жыл бұрын
Understood
L46. Check if a tree is a BST or BT | Validate a BST
9:39
take U forward
Рет қаралды 199 М.
L44. Delete a Node in Binary Search Tree | BST | C++ | Java
15:48
take U forward
Рет қаралды 219 М.
Beat Ronaldo, Win $1,000,000
22:45
MrBeast
Рет қаралды 158 МЛН
Cat mode and a glass of water #family #humor #fun
00:22
Kotiki_Z
Рет қаралды 42 МЛН
The Dome Paradox: A Loophole in Newton's Laws
22:59
Up and Atom
Рет қаралды 716 М.
L52. Recover BST | Correct BST with two nodes swapped
15:56
take U forward
Рет қаралды 137 М.
L50. Binary Search Tree Iterator | BST | O(H) Space
14:00
take U forward
Рет қаралды 154 М.
10.1 AVL Tree - Insertion and Rotations
43:08
Abdul Bari
Рет қаралды 1,3 МЛН
L48. Construct a BST from a preorder traversal | 3 Methods
16:32
take U forward
Рет қаралды 179 М.
L37. Morris Traversal | Preorder | Inorder | C++ | Java
23:50
take U forward
Рет қаралды 273 М.
L5. Next Greater Element | Stack and Queue Playlist
18:25
take U forward
Рет қаралды 75 М.
2.6.3 Heap - Heap Sort - Heapify - Priority Queues
51:08
Abdul Bari
Рет қаралды 2,2 МЛН