L45. K-th Smallest/Largest Element in BST

Поділитися
Вставка
  • Опубліковано 7 січ 2025

КОМЕНТАРІ • 194

  • @takeUforward
    @takeUforward  3 роки тому +74

    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 роки тому +1

      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 роки тому +280

    for kth largest we can do a reverse inorder kind of thing: RIGHT ROOT LEFT with the counter logic

  • @GauravKumar-dw2ml
    @GauravKumar-dw2ml 2 роки тому +48

    For kth largest just do the reverse in-order , and print the kth element. Bcoz this will lead to decreasing order.

  • @mohdhammadsiddiqui7598
    @mohdhammadsiddiqui7598 2 роки тому +38

    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 роки тому +2

      sahi hai!!

    • @amanali9501
      @amanali9501 2 роки тому +5

      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.

  • @kushagraahire1871
    @kushagraahire1871 Рік тому +20

    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);
    }
    }

  • @parikshitsinghrathore6130
    @parikshitsinghrathore6130 2 роки тому +12

    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 місяців тому +1

    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 6 місяців тому

      so its post order right?

    • @wttc4
      @wttc4 6 місяців тому

      @@ChayK11 no, postorder traversal is: left->right->root

  • @vaishnavigour5777
    @vaishnavigour5777 2 роки тому +20

    for Kth largest it should be (n-k+1)th smallest

  • @stith_pragya
    @stith_pragya 7 місяців тому +1

    Understood.............Thank You So Much for this wonderful video.....🙏🏻🙏🏻🙏🏻🙏🏻🙏🏻🙏🏻

  • @ishankbansal9239
    @ishankbansal9239 3 роки тому +13

    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 роки тому +7

      @@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?

  • @abcsumits
    @abcsumits 2 роки тому +2

    why not we visit directly right first and left after while treversing for k th max. :) it will be done in one treversal

  • @budhadityachatterjee6270
    @budhadityachatterjee6270 3 роки тому +9

    Diwali pe DP Series aa rha hain kya ?

  • @akshayteja2864
    @akshayteja2864 6 місяців тому +2

    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;
    }
    };

  • @pranshumehta3228
    @pranshumehta3228 2 роки тому +7

    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 роки тому +3

      Yes, but at most K is equal to n (e.g. k=n) . So, the worst case scenario is O(n).

    • @imPriyansh77
      @imPriyansh77 10 місяців тому

      worst case scenario would be O(N)

  • @aayushprajapati347
    @aayushprajapati347 3 роки тому +21

    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;
    }

  • @mridulsarma9022
    @mridulsarma9022 3 роки тому +9

    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

  • @xavier6955
    @xavier6955 3 роки тому +13

    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 роки тому +5

      I can't believe you are in I.T

    • @xavier6955
      @xavier6955 3 роки тому +9

      @@geekaffairs6475 I am not in IT, I am the IT.

    • @utkarshverma2604
      @utkarshverma2604 3 роки тому +2

      @@geekaffairs6475 samw bro ye banda har jagah h

  • @divyanshusingh2396
    @divyanshusingh2396 2 роки тому +2

    If we use inorder then there will be no need of sorting… because inorder of bst is already sorted

  • @AlokSingh-qj3hf
    @AlokSingh-qj3hf 19 днів тому

    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

  • @ahustler110
    @ahustler110 Місяць тому +1

    but why will we sort?? inorder of bst is already sorted array in incresing order

  • @mrrealnobody4382
    @mrrealnobody4382 11 днів тому

    What about the Follow up: If the BST is modified often (i.e., we can do insert and delete operations) and you need to find the kth smallest frequently, how would you optimize?

  • @shantanugupta-oz1dx
    @shantanugupta-oz1dx 5 місяців тому

    Thank you for the simple explanation

  • @ankittjindal
    @ankittjindal 3 роки тому +2

    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!!

  • @ChetanSingh-zp4ct
    @ChetanSingh-zp4ct 2 роки тому +11

    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 роки тому +1

      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?

  • @MadhavGupta-fi2tu
    @MadhavGupta-fi2tu Рік тому +6

    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;
    }
    };

  • @shivangisrivastava1158
    @shivangisrivastava1158 3 роки тому +1

    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 🥹🥹

  • @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];
    }
    };

  • @AbhishekPandey-dj2eo
    @AbhishekPandey-dj2eo Рік тому

    Keep doing this GOOD WORK

  • @prasannamalatesha3887
    @prasannamalatesha3887 Рік тому

    Great explanation bro. Perfectly explained all the possible solutions for this problem

  • @izumi7754
    @izumi7754 8 місяців тому +3

    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 місяців тому +1

      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 6 місяців тому

      He's providing quality content for free, and still you are complaining for a small mistake?

  • @tech_wizard9315
    @tech_wizard9315 3 роки тому +5

    Is your tree series enough for DSA beginners for Tech interviews of companies like Microsoft , linkedin etc?

  • @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);
    }

  • @abhijitroy1958
    @abhijitroy1958 2 роки тому +2

    when you were explaining the brut ,i accidentally coded the optimal by using morries xd

  • @tanveer.shaikh
    @tanveer.shaikh 2 роки тому +1

    I did not understand why you need to sort the elements, if we do inorder traversal we could do it in o(n),

  • @sagarkakkar4150
    @sagarkakkar4150 Рік тому +1

    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

  • @arjunkurariya2235
    @arjunkurariya2235 3 роки тому +4

    Best Series ever seen❤️❤️. Is CP necessary for CODING ROUND..??? PLS ANSWER 🙏🙏🙏

  • @sparshsharma3150
    @sparshsharma3150 3 роки тому +9

    Striver's video explanation --- mind blown
    Striver's video explanation with face cam ---- mind blown ultra pro max 😂😂

  • @rakhshanahmad8057
    @rakhshanahmad8057 10 місяців тому

    Great explanation. Those last approaches are great.

  • @isheep9025
    @isheep9025 Рік тому +1

    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

  • @alesblaze4745
    @alesblaze4745 2 роки тому +4

    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 роки тому +1

      Nice dp...Daffodils, isn't it?

  • @abhinavkumar6584
    @abhinavkumar6584 2 роки тому +2

    shouldn't kth largest should be n-k+1 ??? Anyone?

  • @Usurperhk
    @Usurperhk 3 роки тому +3

    Bhaiya this is the best evolution of your videos. Left side knowledge right side legend. It's f***king awesome bhaiya. 🙂🙂🙂

  • @mayankbisht1277
    @mayankbisht1277 3 місяці тому

    For largest why not do [Right,Node,Left] ?

  • @aryansinha1818
    @aryansinha1818 2 роки тому

    06:40 Largest

  • @KnowledgeofEverything
    @KnowledgeofEverything 3 роки тому +2

    New setup is good .... But I don't think it matters much .... For me your content matters more and it's great

  • @aryanchaurasia1081
    @aryanchaurasia1081 Рік тому

    For kth largest we can do right root left traversal

  • @shubamgoswami
    @shubamgoswami 3 роки тому +1

    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.

  • @JEAnandkumar
    @JEAnandkumar 2 роки тому +1

    One correction:
    k th largest element = (n-k+1)th smallest element

    • @parthsalat
      @parthsalat 2 роки тому

      Exactly! I was thinking about this

  • @anshulgoel1940
    @anshulgoel1940 Рік тому

    Can we do R N L for Kth largest using morris? I just tried a psuedo code seems possible.

  • @pvenkatesh3690
    @pvenkatesh3690 Місяць тому

    It's looking kth largest approach is wrong. it should be Kth largest = (N-K) + 1 smallest element

  • @reddysasikiran315
    @reddysasikiran315 3 місяці тому

    what if duplicate elements are there

  • @ankitkr09
    @ankitkr09 3 роки тому +1

    Agar ek din pehle upload kr deta bhai toh mera amazon clear ho jata..

  • @sakshamsengar9798
    @sakshamsengar9798 2 роки тому +1

    shoudn't it be for kth largest we need n-k+1th smallest?????

  • @dingo_5998
    @dingo_5998 2 роки тому +1

    Thank you bhaiya Meet me in G.😎😎😎😎

  • @AnandSingh-zm5cm
    @AnandSingh-zm5cm 3 роки тому

    Why we need to sort?Inorder always gave sorted elements

    • @imPriyansh77
      @imPriyansh77 10 місяців тому

      we need to sort only if we're implementing preorder, postorder or level order.

  • @santoshkumarroy5070
    @santoshkumarroy5070 2 роки тому

    explanation on point . loved it bhaiya

  • @sushantbhosale5792
    @sushantbhosale5792 3 роки тому +1

    Striver bhaiya aur kitne videos baki he playlist ke when it will be completed??

  • @hitenrana4775
    @hitenrana4775 2 роки тому +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 роки тому +1

      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.

  • @naman_goyal
    @naman_goyal 3 роки тому +1

    Ab maza aayega na bidu💝👍

  • @ANANDKUMAR-hd8mj
    @ANANDKUMAR-hd8mj 24 дні тому

    nice concept

  • @vaalarivan_p
    @vaalarivan_p Рік тому

    4:25

  • @geekaffairs6475
    @geekaffairs6475 3 роки тому +1

    Amazing explanation.

  • @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;

    }
    };

  • @codeman3828
    @codeman3828 8 місяців тому

    Understood. Thanks

  • @lavanyaprakashjampana933
    @lavanyaprakashjampana933 2 роки тому

    we love your content and we love you...🖤

  • @UECAshutoshKumar
    @UECAshutoshKumar Рік тому +1

    Thank you sir

  • @VIRAJBHOSLE
    @VIRAJBHOSLE 2 роки тому +3

    need to improve this video. not very clear

  • @sankalpietechtips
    @sankalpietechtips Рік тому

    Thanks bro, you did good

  • @shouvikdatta6831
    @shouvikdatta6831 3 роки тому

    Man, after DP, make a series on stack & queue..

  • @Anonymous-uj3jx
    @Anonymous-uj3jx 2 роки тому

    Understood thanks :)

  • @aditya-st1sv
    @aditya-st1sv 3 роки тому

    #Striveronfire 🔥🔥🔥

  • @mohitsingh7793
    @mohitsingh7793 2 роки тому

    kth largest=(n-k+1)th smallest element.

  • @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

  • @Girish415
    @Girish415 3 роки тому

    Thank you

  • @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

  • @mehulmorker258
    @mehulmorker258 2 роки тому

    C++ code link opens Javacode and Java code link opens C++ code. Edit That Bro 😇

  • @adityapandey23
    @adityapandey23 3 місяці тому

    Understood

  • @KartikeyTT
    @KartikeyTT 5 місяців тому

    tysm sir

  • @sundarbsr4275
    @sundarbsr4275 Рік тому

    understand ❤

  • @anubhavverma7193
    @anubhavverma7193 3 місяці тому +1

    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)

  • @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)

  • @shashankojha3452
    @shashankojha3452 3 роки тому

    That makes sense

  • @harshitjaiswal9439
    @harshitjaiswal9439 10 місяців тому

    understood.

  • @chiragbansod8252
    @chiragbansod8252 10 місяців тому

    understood

  • @purushottam108
    @purushottam108 6 місяців тому

    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.

  • @roopeshn3301
    @roopeshn3301 2 роки тому

    Understood

  • @preetikushwaha8734
    @preetikushwaha8734 3 роки тому

    Finally 🔥

  • @shantipriya370
    @shantipriya370 11 місяців тому

    us..

  • @ajayypalsingh
    @ajayypalsingh 2 роки тому

    💚

  • @NikhilGupta-zo5jh
    @NikhilGupta-zo5jh 2 роки тому

    understood

  • @momilijaz271
    @momilijaz271 3 роки тому

    done!

  • @suvanshmahajan5902
    @suvanshmahajan5902 2 роки тому

    "us"

  • @p38_amankuldeep75
    @p38_amankuldeep75 2 роки тому

    💝💙💝

  • @piyushacharya7696
    @piyushacharya7696 2 роки тому

    reach++

  • @KaushikSharma-c3q
    @KaushikSharma-c3q Рік тому

    .....................

  • @Girish415
    @Girish415 3 роки тому

    Coolm

  • @SHASHANKRUSTAGII
    @SHASHANKRUSTAGII 3 роки тому

    im the 400 like

  • @JEAnandkumar
    @JEAnandkumar 2 роки тому +109

    One correction:
    k th largest element = (n-k+1)th smallest element

  • @sibiranganath
    @sibiranganath 2 місяці тому

    Understood

  • @abhinanda7049
    @abhinanda7049 8 місяців тому

    understood