Decode String - Leetcode 394 - Python

Поділитися
Вставка
  • Опубліковано 27 гру 2024

КОМЕНТАРІ • 112

  • @TheElementFive
    @TheElementFive 2 роки тому +51

    Very comprehensive problem to practice stacks! Together with asteroid collision and daily temps, one can argue understanding those 3 problems alone are a solid prep for stack problems on interviews.

  • @ShivangiSingh-wc3gk
    @ShivangiSingh-wc3gk 2 роки тому +21

    Did this myself and came to see the solution. I am so happy to see my progress. Thank you soooo much!!!

  • @gazijarin8866
    @gazijarin8866 5 місяців тому +4

    The fact that you appended the string AFTER the pop made the problem so easy. I was shaking my head in horror trying to reverse the string once after appending it.

  • @Iamnoone56
    @Iamnoone56 3 роки тому +87

    this was asked in my amazon sde 1 interview somehow i managed t solved it. holy cow!

    • @xinli7477
      @xinli7477 2 роки тому +18

      Wow, they ask such difficult questions for sde 1? Congrats on solving it!

    • @PP-pe3fs
      @PP-pe3fs Рік тому +7

      You have my respect

  • @harishsn4866
    @harishsn4866 2 роки тому +24

    I know you probably hear this a lot but your explanations are so clear and easy to grasp. Thanks a ton for this.

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

      It's no wonder Google hired him in a heartbeat.
      NeetCode has a great talent for reducing complex problems into simplest and digestible way.

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

    Great explanation and diagrams!! This is what I got:
    The things to decode have this pattern: Coefficient(content)
    2 things needed:coefficient, and content
    My approach using stack was adding just the {}, and tracking the indexes for substring
    , but I like your approach is cleaner by adding everything to stack.
    General approach:
    for all chars in string
    if stack is Empty:
    if isDigit: calculate the numerical part/coefficient,
    if (, add to stack, save startindex
    if is character, add to string builder
    if stack is not empty:
    add everything
    if is ), remove from stack
    if stack is empty, recursively call helper(s.substring(startIndex+1, endIndex)

  • @amogchandrashekar8159
    @amogchandrashekar8159 3 роки тому +30

    You make things feel so easy!
    Thank you so much 😀

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

      Then maybe its just me who still didn't understood it.

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

      @@varunshrivastava2706 I would ask that you watch it again if so and jott what you can as you follow along
      Bless🙏

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

    this is a very good explanation, very concise and clear code. I implemented this in C++ and got 100% time and 96% memory.

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

      please send me cpp code i am getting wrong answer in one test case

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

      This is my code:
      class Solution
      {
      public:
      string stuff(int n,string s)
      {
      string t;
      while(n--) t+=s;
      return t;
      }
      int stringToNum(string s)
      {
      int num=0;
      for(int i=0;i

  • @SriHarishPopuri
    @SriHarishPopuri 4 місяці тому +2

    The sub string calculation in this solution (which is done twice btw) is a costly operation to do, both in time and space. Strings are immutable and this above way of calculating substrings can lead to quadratic time complexity when calculating the multiplier or inner string between square brackets, when there are large inputs. Instead, the characters can be appended to a list and joined using "".join(list) method, which will have linear time complexity. Thats a lot better in terms of the time and space complexities.

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

    First coding channel on UA-cam that I put the bell icon to receive all updates for !!

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

    According to LeetCode premium, the time complexity of this solution is actually O(maxK^countK * n), where maxK is the maximum value of k, countK is the count of nested k values and n is the maximum length of the encoded string. Example, for s = 20[a10[bc]], maxK is 20, countK is 2 as there are 2 nested k values (20 and 10). Also, there are 2 encoded strings a and bc with the maximum length of the encoded string n as 2.

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

    Amazingly explained, was able to implement without even looking at code. Thank you!

  • @susmi51910
    @susmi51910 3 роки тому +12

    You explain these problems so well! can you please do a video on the problem " Guess the word" ?

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

    You are coding god, man. You're in my idol list, right next Van Halen!

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

    Thanks, i ended up solving this with recursion on my first attempt. I used this video to learn how to apply stacks to the problem. Thank you.

  • @begenchorazgeldiyev5298
    @begenchorazgeldiyev5298 2 роки тому +6

    I don't know why I am still using java. I came up with the same solution with a stack but it is at least twice longer thanks to java. This is so easy to read and comprehend.

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

      Lol same bro. Python is the best language for interviews in my opinion.

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

      yup, hope you made the siwtch.

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

    One of the best solution availabe on YT. Great work sir. Huge fan of the way you break tough and/or complex problems into simpler versions!!😍😍

  • @mercymutuku4525
    @mercymutuku4525 27 днів тому

    Amazing solution as always. Instead of checking for "[" and popping twice, I used not(stack[-1].isdigit()). Then, in the first while loop, break if the popped value is "["

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

    Love your videos, the clearest explainations I've come across among all the other ones ... Keep it up!

  • @ren-hauchuang2005
    @ren-hauchuang2005 3 роки тому +3

    This is the way better solution than official ones

  • @thndesmondsaid
    @thndesmondsaid 4 місяці тому +1

    aw man, tried this on my own and thought to use a stack but couldn't figure out the algo. Thank you!

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

    This is actually the best tutorial I found on the internet

  • @pif5023
    @pif5023 9 місяців тому

    Great video! Thanks! This problem showed me stacks are amazing for accruing and backtracking in an organic way!

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

    i think if we consider the length of the output string is K
    then the time complx will be linear in this length K -> O(k) ;

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

    Best explanation man! TYSM for your efforts.

  • @jinny5025
    @jinny5025 3 роки тому +7

    Best explanation as always!

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

    wow usually I feel a bit anxious when not able to come up with a soln, I have been watching ur few vids! explanations r crisp and easy to understand, I even like it's in python while I code in cpp lol

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

    much easier to understand than upvoted solutions which I could never do interview.

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

    Terrific explanation!!

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

    A very excellent problem and explanation!

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

    I solved this a different way in linear time by using two stacks; one of factors where the top of the stack is the last number for the characters and another stack containing the substrings. whenever a ] character is detected it pops the two from their respective stacks, multiplies them, then appends it to the next top of the characters stack.

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

    Man this is so easy in python .. i was doing it in C++ . i had the same logic but implementation was so tough for it

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

    Great explanation !!
    I was wondering whether we can do it solely by recursion calls?

  • @atulkumar-bb7vi
    @atulkumar-bb7vi Рік тому

    Explanation put very simple way, thanks for this!

  • @adityavikrant3847
    @adityavikrant3847 4 місяці тому

    Great solution! Could you explain why we need to check whether the stack exists before popping digits?

  • @arun-ph9cn
    @arun-ph9cn 2 роки тому

    WOW. the solution and explanation is simply superb!!

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

    Phenomenal explanation!!

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

    Is there a reason you always do range(len(s)) instead of for x in s or enumerate(s)? I've been watching a lot of of these (great) videos and I noticed that, so I'm wondering...

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

    Your way of explanation awsome

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

    How long do you actually take to solve these questions for the first time? It seems to take more than 1.5hrs for me.

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

    Great clear explanation as always. thanks

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

    I did everything same except :
    substr+=stack.pop()
    and finally, substr=substr[::-1]
    and similar for k
    how m i am failing a test case. Could you please explain the difference ?
    Failed test case:"3[z]2[2[y]pq4[2[jk]e1[f]]]ef"

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

      I guess you essentially have substr = substr + pop instead of pop + substr, so the order of letters are not the same.

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

      I even getting the wrong answer in cpp with the same test you failed.Please tell where i did wrong.
      class Solution
      {
      public:
      string stuff(int n,string s)
      {
      string t;
      while(n--) t+=s;
      return t;
      }
      int stringToNum(string s)
      {
      int num=0;
      for(int i=0;i

  • @tanmay07777
    @tanmay07777 23 дні тому

    what a code! beauty!

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

    How are you accounting for this edge case ? “vvvlo”
    Your algo would return “vlovv” or “”
    Where a string is possible “vlvov”

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

    Thanks for the video. Can you also do the Encode verion of this the (Leetcode 471) ?

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

    You are amazing, Thanks a lot
    Lots of love

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

    Well explained.

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

    It's much easier to write it in Python than in Java.

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

    very neat code

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

    thank you so much sir for this amazing explaination🙇‍♂❤

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

    great video, thanks

  • @Cloud-577
    @Cloud-577 2 роки тому

    recursive is same as maintaining our own stack

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

    stack makes this problem pretty much easier

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

    This was asked in Zoho software developer role

  • @Gaurav-ln8ze
    @Gaurav-ln8ze Рік тому +2

    Thank you so much sir for your great and clear explanation.
    Here the code in c++ :-
    class Solution {
    public:
    string decodeString(string s) {
    string ans="", substr="", k;
    int n=s.size();
    stack st;
    for(int i=0; i

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

    I was giving this problem for google's phone interview today. I didn't do as well :(

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

    Just got this for a new grad position and I failed it miserably, should have watched more vids :(

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

    what is the space complexity?

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

    Thanks bro u the man

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

    the part where you did “while stack and stack[-1].isdigit():” kinda confuses me. Isn’t the stack always nonempty? There always has to be an integer in front of ‘[‘, otherwise we don’t even need to use brackets. Validating whether the stack is empty or not doesn’t seem to be necessary, but the code doesn’t work if I don’t validate it. I’m so lost here

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

      If our input is "23[a]", when we get to line 15 our stack will contain just [2, 3], we have to keep popping numbers but we need to stop once the stack is empty else we'll get an index error when doing stack[-1].isdigit() check.
      The isdigit() check catches the following case: input = 23[a4[b]] then our stack will be [2, 3, [, a, 4] when we get to that line 15, isdigit() will make sure we don't pop past the number 4 for the current substring we're building.

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

      @@D_T244 ohh i didnt consider the case where the integer is a 2digit number. Thansk!!

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

    It seems leetcode added a testcase and this code no longer works

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

      **This Works**
      class Solution:
      def decodeString(self, s: str) -> str:
      out_str = []
      digit = 0
      for i in range(len(s)):
      if s[i] != "]":
      out_str.append(s[i])
      if s[i].isdigit():
      digit += 1
      else:
      sub_str = ""
      while out_str[-1] != "[":
      sub_str = out_str.pop() + sub_str
      out_str.pop()
      n = ""
      while out_str and out_str[-1].isdigit():
      n = out_str.pop() + n
      n = int(n)
      out_str.append(int(n)*sub_str)
      if digit == len(s):
      return ""
      else:
      return "".join(out_str)

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

    Amazing explanation but i cant think of why i cant solve it by myself

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

    should line 16: k = stack.pop() * 10 +k ?

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

      Then the digits of K number would be in the wrong order.
      Popping from the stack retrieves the digits in reverse order.
      Stepping it through in a debugger makes it easy to see.

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

    thank you sir

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

    is there another way to solve this without using Stack?

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

    The example showed with 54[ab] which has a 2 digits number. But the solution doesn't account for it. Hope you have time to update the video.

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

      Actually it does.
      Line 15 while loop builds a string which then gets converted to Int on Line 17.

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

      @@CostaKazistov Thank you! It's my bad, sorry.

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

    GOAT

  • @ChinmayAnaokar-xm4ci
    @ChinmayAnaokar-xm4ci 2 роки тому

    C# code for above logic :
    public static class AppHelper
    {
    public static String DecodeString(String s)
    {
    Stack st = new Stack();
    for (int i = 0; i < s.Length; i++)
    {
    if (s[i] != ']')
    {
    st.Push(s[i]);
    }
    else
    {
    string curr_str = "";
    while (st.Peek() != '[')
    {
    curr_str = st.Peek() + curr_str;
    st.Pop();
    }
    st.Pop();
    string number = "";
    while (st.Count > 0 && Char.IsDigit(st.Peek()))
    {
    number = st.Peek() + number;
    st.Pop();
    }
    int noKTimes = Convert.ToInt32(number);
    while (noKTimes > 0)
    {
    for (int p = 0; p < curr_str.Length; p++)
    {
    st.Push(curr_str[p]);
    }
    noKTimes--;
    }
    }
    }
    s = "";
    while (st.Count > 0)
    {
    s = st.Peek() + s;
    st.Pop();
    }
    return s;
    }
    }

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

    I don't think the code can cover the corner case as "3"

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

    my c++ solution(same logic as explained in the video):
    class Solution {
    public:
    string decodeString(string s) {
    stack stk;
    string str = "";
    for(auto it: s) {
    if(it >= 'a' and it = '0' and it = "0" and stk.top() 0) counts = stoi(count);
    for(int i = 0; i < counts - 1; i++) str += str1;
    stk.push(str);
    }
    }
    string ans = "";
    while(!stk.empty()) {
    ans = stk.top() + ans.substr(0, ans.length());
    stk.pop();
    }
    return ans;
    }
    };

  • @vai3348-p6t
    @vai3348-p6t 3 роки тому +1

    Can someone compare iterative solution vs recursive solution, in terms of time complexity and suggest which one is better approach?

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

    U a God

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

    It is so difficult to put Sting and Character in the same stack.

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

    Very Nice Explanation. Thanks, Buddy...

  • @shivamvishawakarma-z6o
    @shivamvishawakarma-z6o Рік тому

    can any one explain the time complexity of it

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

    Will the interviewer accept regex?

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

    support

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

    can anyone help me in solving it in recursively

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

    Need recursive solution

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

      Recursive solution would be easier to code up, yes.
      But the above solution would be preferred in an interview setting.

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

    🐐

  • @YohannesAsfaw-b8b
    @YohannesAsfaw-b8b 10 місяців тому

    can you do this using recurssion

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

    Instead of concatenating to string, I appended them all to a list, and called list.reverse() 😅😅
    p.s. Stop scrolling comments, and solve some probolems.

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

    i don't understand why does it work

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

    wow

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

    every time he said "IN PYTHON", I was looking at my Java code, it was like speaking to me: What? don't look at me like that, go and search on google.

  • @Tony-un9mg
    @Tony-un9mg Рік тому

    GOAT