Is Subsequence - Leetcode 392

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

КОМЕНТАРІ • 43

  • @vikrampalpatel
    @vikrampalpatel 2 роки тому +63

    Why is like after watching your explanations, every problem looks easy!

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

    Was struggling to understand two pointers. This is a great place to start. Thanks

  • @illu1na
    @illu1na Рік тому +11

    Can you also cover the follow up question for this problem please?

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

    A lot of people ask why the question is given under the DP tag. This is because to find the length of the longest common subsequence, we need DP.

  • @josecabrera7947
    @josecabrera7947 2 роки тому +19

    Dude mark my words if I get this internship with google or amazon in Seattle for summer 2023 I will personally take you to dinner !!!!

  • @nanoname5226
    @nanoname5226 3 роки тому +10

    Could you also address the follow up element of this problem? The one that talks about a stream of query strings "s" coming in.

    • @vasujhawar.6987
      @vasujhawar.6987 Рік тому

      thats why I came here

    • @jayjw1
      @jayjw1 Рік тому +2

      I'm not sure if there's more to it, but wouldn't you just check if s > t: return False automatically because s can't be a subsequence if it's larger than the entirety of t?

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

      @@jayjw1 No, the follow-up element isnt talking about any specific s, it's talking about how to be more efficient if there are multiple s being sent to our function, how can we evaluate each s in an efficient way?

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

    Thank you so much I was able to write my own Java code by using your logic

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

    Pretty neet answer, thanks. The return statement could've been: return i == len(s)

  • @fanyang9777
    @fanyang9777 3 роки тому +6

    awesome lesson as always!

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

    Best simplest solution

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

    How is this a DP problem ? Can u plz elaborate how this is breaking up into overlapping subproblems and optimal substructure ?

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

      To find the length of the LCS, we need DP. This one is a simple two-pointer solution.

  • @farrukhniaz3218
    @farrukhniaz3218 Рік тому +2

    instead of if else in return statement, write
    return i == len(s)

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

    DP solution:
    It is easy to think of this if you finished 10. regular expression matching.
    def isSubsequence(self, s: str, t: str) -> bool:
    if len(s) > len(t):
    return False

    dp = [[False] * (len(t) + 1) for _ in range(len(s) + 1)]

    for j in range(len(t) + 1):
    dp[len(s)][j] = True
    for i in range(len(s) - 1, -1, -1):
    for j in range(len(t) - 1, -1, -1):
    match = s[i] == t[j]
    if match:
    dp[i][j] = dp[i + 1][j + 1]
    else:
    dp[i][j] = dp[i][j + 1]
    return dp[0][0]

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

    In the two pointer approach, I did not understand one thing the ordering also has to be checked in a subsequence which is missing for the problem in the testcases, for instance here s = "acg" and t = "ahbgdc", they are considering s as a subsequence of t which should not be so, as the ordering is not maintained, although all elements are present from s in t.

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

      did u ever figure it out? im wondering the same

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

    this man is a hero

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

    you earned a subscriber today 👍👍.

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

    Thanks a lot .This video helped me a lot !!

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

    Thank you so much. You saved my day

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

    but wouldn't the while loop keeping looping endlessly if i is never incremented? because your'e only incrementing i if s[i] = s[j]. what if it never equals ?

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

      then j will keep incrementing and eventually stop the loop

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

    Thank you bro.A love from tamil nadu

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

    Thank you NeetCode. One can just return `i == len(s)`

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

    Awesome explanation

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

    bro are you genius!!

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

    thank you so much!

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

    This one killed me for some stupid reason -.-

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

    I'm still Scratching my head, what if it's not in the sequence?

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

    return i == len(s)
    concise

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

    Excellent

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

    Bro what if it is wrong order acb,abcdef

    • @Track-Tor
      @Track-Tor 3 роки тому +1

      he explains it at 1:32

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

      Then it won't be a subsequence, as he explained

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

      It is handled through increment of j

  • @praneeth8380
    @praneeth8380 7 місяців тому

    def isSubsequence(s, t):
    if all(j in t for j in s):
    return True
    else:
    return False

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

    Thank you very much!