I have two questions: 1. insted of while loop , why not use if...else 2. after while loop: instead of removing and updating the char in sett, why not add string in sett first and start update "longest"
instead of using set, using key value pair object, to track the last index a character is found so that {a:0, b:1, c:2}, then when a second a is found if we update the a index to {a:3, b:1, c:2} then left pointer to original a index +1, are we able to save the extra looping until finding valid substring?
@@foudilbenouci482 O(n/c) could be reduced to O(n) or am I wrong cause I thought you can reduce multiplication and division but can reduce addition and subtraction
i don't know why the code I have written is exactly same instead of set I used hash map should i have used hash set?? is hash map is the main cause of output limit exceeded??
@@freshedits8408 Can you explain why it's not an index because I see sett.remove(s[l]) and then l += 1 so shouldn't it be removing sett at index 0 and then moving up? This is something that I am confused by as well. When you add items to the set the first item you add doesn't necessarily stay at index 0
@@salxs9664 no, here s means string so we are removing a first index of the string Suppose if s[l] means "a" which is the first index in the string and we are removing "a" from the set like set.remove("a"). If the char already exists then we are removing it. Every time we remove, we are changing the starting index
Master Data Structures & Algorithms For FREE at AlgoMap.io!
Best Explanation. Its Crystal Clear
Best explaINATION ON THIS TOPIC ON YT..
Best solution I've seen. Thanks
lol thats literally what I said. Best explanation too.
great explanation!
Best solution Ive seen. Nice!
I have two questions:
1. insted of while loop , why not use if...else
2. after while loop: instead of removing and updating the char in sett, why not add string in sett first and start update "longest"
instead of using set, using key value pair object, to track the last index a character is found so that {a:0, b:1, c:2}, then when a second a is found if we update the a index to {a:3, b:1, c:2} then left pointer to original a index +1, are we able to save the extra looping until finding valid substring?
Great explanation ! It would be great if you would share the leetcode problem link in description so that we can implement ourselves after learning
Technically the size of the set will be limited by the character set used, so can we call it O(1) space?
Oops did I say O(n) space? You're completely correct, yes!
Thanks for clarifying!
more exactly O(n/c) where c is the capacity of the character set used and n the size of the string
@@foudilbenouci482 O(n/c) could be reduced to O(n) or am I wrong cause I thought you can reduce multiplication and division but can reduce addition and subtraction
Get the length of the set instead when comparing. Much easier to think intuitively
It's a basic one but please I have question what if we use if s(r) in seen willl it be completely wrong but by what sense. Since you were using while.
Good explanation, thank you!
i don't know why the code I have written is exactly same instead of set I used hash map should i have used hash set?? is hash map is the main cause of output limit exceeded??
set doesnt preserve insertion order. so how removing of elements is working here.?
They are removing based on the actual character, but not with an index so it is working.
@@freshedits8408 Can you explain why it's not an index because I see sett.remove(s[l]) and then l += 1 so shouldn't it be removing sett at index 0 and then moving up? This is something that I am confused by as well. When you add items to the set the first item you add doesn't necessarily stay at index 0
@@salxs9664 no,
here s means string so we are removing a first index of the string
Suppose if s[l] means "a" which is the first index in the string and we are removing "a" from the set like set.remove("a").
If the char already exists then we are removing it.
Every time we remove, we are changing the starting index
@@freshedits8408 Thank you that explains it!
Hi there, are you still available for 1o1 trainings sessions?
Yes, please email greg.hogg1@outlook.com
@@GregHogg done, waiting for your reply.
"When window is valid we move R, when it's invalid we move L". Had to type it to memorize