Stack Data Structure | JavaScript

Поделиться
HTML-код
  • Опубликовано: 18 янв 2025

Комментарии • 321

  • @TraversyMedia
    @TraversyMedia  4 года назад +201

    This will be an ongoing series. I know it is a bit different than the projects/crash courses I usually do, but it is really good practice. I will be reviving the JS Cardio series as well. Maybe do some Codewars :)

    • @tomershechner
      @tomershechner 4 года назад +9

      I'll just lay a couple of DSes ideas for your next videos:
      - Hash tables (associative arrays, aka maps)
      - Dynamic array (aka vectors)
      - Binary trees
      - Queues
      - Heaps
      - Sets
      I implemented them all in C once, it'll be cool to see you using a language other than JS, something which is closer to the metal, like C, Rust or even Go.
      Peace Brad, I appreciate the effort you put into your videos!

    • @swanstudios2018
      @swanstudios2018 4 года назад

      Traversy Media love some code wars that would be a nice mix of content! Thanks so much brad!

    • @khotambakhromov
      @khotambakhromov 4 года назад +5

      how the method pop removes element? tbh, I couldn't find out how it works and deletes item

    • @Buyilehuorg
      @Buyilehuorg 4 года назад +3

      shouldn't we add this.items.pop() inside pop method? otherwise it's kinda still there, no? Could you please make examples how to use those with real world implications? I mean examples explaining why we want to use it instead of arrays for instance etc. Thank you very much for your videos and Udemy courses

    • @princesiful
      @princesiful 4 года назад

      great

  • @Ath9394
    @Ath9394 4 года назад +103

    Really happy that brad started data structure series

  • @ryan.aquino
    @ryan.aquino 4 года назад +146

    Please continue this series: data structures and algs. Include stack, queues , heap , graph , trees.
    You explain things simpler than others ! Thanks.
    Edit:
    Include atleast 1 coding problem
    And 1 realworld example.

  • @jmmacatangay_grizzlybear
    @jmmacatangay_grizzlybear 4 года назад

    It's really amazing how people come into your channel. It's about 21 minutes ago in my time and a hundred people seen it already. It's really amazing that a lot of people appreciate you. Been telling my friends about your channel. Really hoping you'll get a billion subscriber someday.

  • @mannyc1065
    @mannyc1065 4 года назад +1

    I'm taking a data Structures course at school next semester so this is perfect timing!! Thank you!

  • @safara_umarov
    @safara_umarov 4 года назад +1

    Really! You are great teacher in the RUclips I'm from Tajikistan and I started learning programming with your videos and now I know many many things. Thank you my brother❤)). With our language not one video about programming and I don't know English good! Your videos help me very. Thank you again

  • @iamjameswong
    @iamjameswong 4 года назад +39

    Hey, nice vid. If I understand it correctly the `.pop` method merely reduces the reference count instead of actually removing the item from the list/stack. Is that right?

    • @srdjagunjic
      @srdjagunjic 4 года назад

      Same...

    • @jeromesnail
      @jeromesnail 4 года назад +1

      The way the stack works, it is exactly like the item was removed from the stack, even if it is still in the items array. Because we're not supposed to access items from outside of the class.

    • @greenie62
      @greenie62 4 года назад +4

      ya i was thinking that too and playing around to try to 'break it'...i realized and am curious for someone to confirm, but in this instance pop feels like its.a rewrite method rather then a remove...by that i mean, it gives us the value but rather then remove it, it just backs the counter up one so the next item we push(), it will then overwrite it as its being given the same index value. so, if you pop() and then look at the array right after, the item is still in there, but soon as you push, then its becomes 'gone' and your stack continues on with its indexed integrity. least thats my guess!

    • @augustodias8986
      @augustodias8986 4 года назад

      I just added this.items[this.count] = undefined
      after decrementing the count

    • @frankkevintankui7221
      @frankkevintankui7221 4 года назад +4

      Same. 😅 It's a great mistake. We also have to manage the memory in data structure

  • @leod.9343
    @leod.9343 4 года назад +1

    We want more data structures and algos ! Please Brad !

  • @soumadip_banerjee
    @soumadip_banerjee 4 года назад +1

    Yaaayyy! Plz! Connect these data structure videos in a series! (small tip: Add some theory too). U're again, my hero in the Tech world! Thankeeww so much! I needed this! 💚

  • @tom.watkins
    @tom.watkins 4 года назад +4

    Great video, only thing that I was surprised to see was the pop method not actually reducing the size of the internal array. Looking forward to the other videos in the playlist!

    • @willmagna
      @willmagna 3 месяца назад

      pop() {
      if (this.count === 0) return undefined;
      this.count -= 1;
      this.items = this.items.slice(0, this.count);
      }

  • @andrewiglinski148
    @andrewiglinski148 4 года назад +13

    Dude I was just messing with react-navigator for react native when I saw this. As soon as I saw this I kind of pee'd a little from overwhelming excitement.

  • @ravijaiswal_7
    @ravijaiswal_7 4 года назад +1

    Looking forward to the complete series of data structures and algorithms, the way you take the flow of your explanation makes things look very easy.

  • @TheNerdyDev
    @TheNerdyDev 4 года назад +1

    Something different. That's great, Brad. What a coincidence, I too was working on a data structure tutorial series but with Java language.

  • @Unbridledhopebr
    @Unbridledhopebr 4 года назад

    Hey, I AM A BIG fan of your work. I can easily understand what you teach. thank you very very much for selling your courses at such an affordable price and outstanding quality. Hug from Brazil.

  • @mykolarositskyi
    @mykolarositskyi 4 года назад

    Thanks, Brad! Really glad to see your videos about Data Structure! Strongly waiting for the rest videos in this area!

  • @srivatsanramesh1739
    @srivatsanramesh1739 4 года назад +26

    Hello Brad.. I have a question. When you’re popping an element from the stack, the element doesn’t actually go out of the ‘items’ array right..? It’s still there. Though you decrement the ‘count’ variable... shouldn’t the element be actually going out of the array..?
    Do correct me if I’m wrong.

    • @dmitrydomanski708
      @dmitrydomanski708 4 года назад +1

      The same question I was going to make

    • @mykalimba
      @mykalimba 4 года назад +1

      Why does it matter? It is _effectively_ removed, from the perspective of whoever is using the API for this class.

    • @tanieltari4539
      @tanieltari4539 4 года назад +7

      @@mykalimba It does matter - you are using less CPU cycles and so your code will be faster. Time spent will be actually noticeably lower, just test it yourself

    • @michaelwilson1771
      @michaelwilson1771 4 года назад +5

      Technically not a memory leak, although the array doesn't shrink after pop. Javascript makes it a little harder to create true leaks due to garbage collection. The array size will only ever be as large as the number of successive push items. After pop, those items will still be in memory, but future pushes will overwrite them. The element references aren't actually lost. Just technically not 'efficient' in memory usage.
      Push 100 items - array size == 100. Pop 100 items - array size ==100. Push 100 more items - array size == 100.
      Also keep in mind @traversymedia was just trying to demonstrate how a stack works. You could do this just as easily with a straight Array using unshift() and pop()

    • @rtorcato
      @rtorcato 4 года назад +6

      The next series will be how to deal with memory leaks

  • @mauricioreyes8912
    @mauricioreyes8912 4 года назад

    Dude, Im coursing data structures in the collegue now, you have this skill to explain things really good. Keep going. Really great channel.

  • @santosokwadi
    @santosokwadi 4 года назад

    Every Video this guys posts, I just click "Like" even before I watch. You have great content Man.

  • @_rachid
    @_rachid 4 года назад +1

    Thank you Mr Brad for this.
    By the way your course Javascript from the beginning on udemy is gold 👌
    Greetings from Morocco 🇲🇦

  • @eriktenecela7170
    @eriktenecela7170 4 года назад

    Bro thanks Traversy man I been telling people these DS/Algorithms are the most important thing to know before anything it will improve your programming mindset dramatically thanks again this channel truly is the best

  • @rezamarefat6894
    @rezamarefat6894 4 года назад

    Please keep making these kinda content brad. Your channel is incredible

  • @princesiful
    @princesiful 4 года назад +1

    Awesome!! Really happy that you started data structure series

  • @eduriseworld
    @eduriseworld 4 года назад +18

    Awesome awesome. I'm going to start videos on Leetcode problems as well. Have my Facebook interview on 8th. Will definitely check these DS videos of yours. :)

    • @eduriseworld
      @eduriseworld 4 года назад +2

      BTW All,
      Facebook Enterprise Team is hiring like crazy at the moment. Pick a Facebook Recruiter from LinkedIn and send them a message that you want to join the "Enterprise Team", they will hook you up with the right department.
      Feel free to ask me if you need help.
      Can't help you get an interview right away, but can definitely guide the way in which you can get an interview.
      I don't work at Facebook (yet!)

    • @tomershechner
      @tomershechner 4 года назад +2

      @@eduriseworld Good luck man, let us all now when you get hired!
      (maybe you'll replace Zuckerberg, who knows ;D ?)

    • @LabaranLabs
      @LabaranLabs 4 года назад

      @@tomershechner sure

  • @abualmahadi8084
    @abualmahadi8084 4 года назад

    Now that you've started the series I'm already feeling confident about finally learning about the data structure and algorithm......sooo much love and respect

  • @Melanittanigra
    @Melanittanigra 4 года назад +3

    Please continue with this series, it is very hard to find information on algorithms and data structures in regards to JavaScript

  • @GTsurwa
    @GTsurwa 4 года назад

    So glad you are doing stuff like this Brad. Still yet to find a web dev job, so videos where I can keep learning really help keep motivated. Thank you 1000 times.

  • @paschalynukwuani6980
    @paschalynukwuani6980 2 года назад +1

    Thank you so much for this video. I really understood everything. I must say you are a good teacher. Love your content 💓

  • @JamieMcGibbon
    @JamieMcGibbon 4 года назад

    Great video! Thanks for taking the time to put it together! Looking forward to the others in the series!

  • @rasulyakubov1461
    @rasulyakubov1461 4 года назад

    I think a new ERA is going to begin for Traversy Media Students and for Brad too :)

  • @indomitablelust
    @indomitablelust 4 года назад +2

    I got a little confused here. Why is the pop method not actually removing the element from the stack? I was thinking that the original stack may still have all the pushed elements at the end but I'm not competely sure. Could someone please explain that part to me?
    Excelent content as always, keep up the good work, man.

  • @xXDameanXx
    @xXDameanXx 4 года назад

    Many thanks for creating this content and sharing this knowledge, algorithms, and design patterns are needed out there but no one is teaching them

  • @jaleotech5918
    @jaleotech5918 4 года назад +30

    pop in the example not actually removing anything.. if you con log items they are all still there. The only thing that is going on is the changing of the counter not the actual array..

    • @mykalimba
      @mykalimba 4 года назад

      Why does it matter? It is _effectively_ removed, from the perspective of whoever is using the API for this class.

    • @vegitax
      @vegitax 4 года назад +8

      @@mykalimba no, it's not. It matters a lot because the values are still in the memory and only the 'pointer' moves and that's not how a stack should work. If this was in a production env somewhere it would undoubtly cause problems at some point.

    • @vegitax
      @vegitax 4 года назад +11

      It bothered me for the whole video that the values were not deleted. I was waiting for the whole time for Brad to notice it because he usually does 😅

    • @kumarraja1989
      @kumarraja1989 4 года назад +1

      Exactly, I am looking for the solution

    • @norricobiason5821
      @norricobiason5821 4 года назад

      @@mykalimba you want to see how isn't popping element in the stack? insert this in pop() method
      let deleteItem = this.items[this.count - 1];
      this.count -= 1;
      console.log(`${deleteItem} removed`);
      console.log(`${this.items}`);

  • @RyanRoat
    @RyanRoat 4 года назад

    The BaseCS podcast has a number of episodes on data structures. They provided a great description of the stack - a spring loaded dish stacker in a cafeteria. The cafeteria pushes the dishes onto the stack, and the diners pop them off when they queue up. Oh, look, there's another data structure. :)
    And yes, I'd like a look at tests to verify the stack is working as expected.

  • @ChaitanyaArige
    @ChaitanyaArige 2 месяца назад

    nice work Brad very clear to understand

  • @xaviguasch
    @xaviguasch 4 года назад

    This is great! I always wanted Brad to tackle data structures and algorithms in JS, please continue.

  • @onedimensionalchess4373
    @onedimensionalchess4373 4 года назад

    Beautiful!! I’m about to get into this topic, so it’s nice to see my favorite teacher explaining it.

  • @Extension-Hub
    @Extension-Hub 4 года назад

    me too Really happy that brad started data structure series I will be right here waiting for Brad

  • @truphenalwanga9829
    @truphenalwanga9829 4 года назад

    Can' t wait to see more on this series. Great start.

  • @swarnalathavura1334
    @swarnalathavura1334 4 года назад +1

    I'm new to this channel recently I joined but it's very nice waiting for more videos I'll support u

  • @cristlui4
    @cristlui4 4 года назад

    Are you a mind reader? This is truly fantastic. Thank you so much Brad!

  • @N63B44TÜ
    @N63B44TÜ 4 года назад

    Great video like always Brad!
    In 4:24 instead of those two lines 10 and 11 you could write :
    return this.count++

  • @annyudo
    @annyudo 3 года назад

    Thank you so much, I really enjoy all your videos, the concepts you use and your explanations are very concise. You are a great teacher. Pls keep up the good work.

  • @mudusugal
    @mudusugal 4 года назад

    your explanations are very clear and easy to understand. Thank you!

  • @MadhusudanBhosale
    @MadhusudanBhosale 4 года назад

    The way you handle errors correction, I just love it.
    #traversymedia #bradtraversy

  • @BBI-Brandboost
    @BBI-Brandboost 4 года назад

    This is great content. We look forward to the next one in the series.

  • @benomayio3666
    @benomayio3666 2 года назад

    Thanks man! I always enjoy your tutorials

  • @novailoveyou
    @novailoveyou 4 года назад

    I would love to see testing! Thanks for your videos Brad!

  • @AneesKhan-uz4mz
    @AneesKhan-uz4mz 4 года назад

    I always feared data structures and algorithms but Brad you just explained really well now I'm loving data structures and algorithms ❤️❤️

  • @retr0477
    @retr0477 4 года назад

    Wow please keep releasing these Data Structures & Algorithms videos. I really appreciate it bro

  • @sujeetagrahari2292
    @sujeetagrahari2292 4 года назад

    I am so glad that you doing this. I have been following this channel very long. I don't come here often now.
    To be honest best channel for beginners to learn new techs.
    But code quality and best practices lack in this channel, and I don't think this should be a concern when you are introduced something new at first.
    But if you get a idea of things in the beginning, it will be lot more beneficial for newcomers..

  • @ThiagoVieira91
    @ThiagoVieira91 4 года назад +1

    Just in time for a productive lunch break! 🙌🏼

  • @akiratoriyama1320
    @akiratoriyama1320 4 года назад

    This is great tutorial sir!! You are helping with our computing thinking!! Thank you!! Hope you made a whole series on data structures because you explain things on simple way!!

  • @woozy_deer
    @woozy_deer 4 года назад +1

    Thanks! I love these data structures videos

  • @sushantkunkekar2155
    @sushantkunkekar2155 4 года назад

    One of the best and simple video on stack... Please Brad do videos on other data structures too. Likr hashtable , tree, dynamic programming

  • @andrei8299
    @andrei8299 4 года назад

    Thanks for the video. Just today got to this topic while learning. It was interesting to know how the mothods structured

  • @mohsin6312
    @mohsin6312 4 года назад

    Thank you Brad. Looking forward to this new series.

  • @barathraj9803
    @barathraj9803 4 года назад

    Wow thank you so much... I was not confident about DS before but now i am sure that i will understand everything.. Thanks, please upload all the vedios exlpaining all the Dta structures.!!

  • @judeokagu6757
    @judeokagu6757 4 года назад

    Finally 😀 Brad to the world 🌎

  • @cubedev4838
    @cubedev4838 4 года назад

    Please continue this kind of series

  • @timurgolovinov
    @timurgolovinov 4 года назад +1

    It would be great if you can also explain where they can be useful in real-world applications, please Brad!

  • @sardorjumanazarov441
    @sardorjumanazarov441 4 года назад

    awesome Brad. I like all lessons, pls keep going

  • @radnerus93
    @radnerus93 4 года назад

    Happy that you started DS❣️

  • @ahmedboutaraa8771
    @ahmedboutaraa8771 4 года назад

    Am was eagerly waiting for more of data structure

  • @kumarraja1989
    @kumarraja1989 4 года назад

    Nice explanation with good examples

  • @cameronthompson1275
    @cameronthompson1275 4 года назад

    Awesome! Great start to data structures! Keep up the great work!

  • @albertdugba
    @albertdugba 4 года назад

    awesome Brad. Having really been looking forward to this. Many thanks big bro

  • @incognitosco
    @incognitosco 4 года назад

    This is great Brad especially for interviews ✅

  • @romanahmed5655
    @romanahmed5655 4 года назад

    Wow..... Nice series .Thank you brad.

  • @theartist8835
    @theartist8835 4 года назад +2

    Hey Brad! Thanks for the amazingly put content. I just wanna say that you forgot to remove the last elemnt from the items array in the pop method!

    • @praveengautam4689
      @praveengautam4689 2 года назад

      yes i am stuck in pop method can you please explain the correction in pop method

  • @ahmad-murery
    @ahmad-murery 4 года назад

    This will be a great series I think,
    About the pop method, the item didn't actually deleted and still occupying memory which may cause some problems if we were stacking big chunks of data,
    the idea was to not use any array's built-in method to pop the item out of the stack (using pop() or re-assign array.length property),
    I found this article about Memory Management
    developer.mozilla.org/en-US/docs/Web/JavaScript/Memory_Management
    and it states that there is no manual way to trigger the garbage collector, so maybe all we can do is to use delete operator or assign null to the item and leave it for garbage collector to do its job
    Regards & waiting for more videos like this

  • @andrewclarke6916
    @andrewclarke6916 4 года назад

    Thanks for this, Brad. Really looking forward to this series. It will probably involve you having to explain some concepts with diagrams though, which you're not so keen on doing.

  • @alisiraj2100
    @alisiraj2100 4 года назад

    Thanx brad, Ur tutorials are amazing

  • @sindhuriskitchen
    @sindhuriskitchen 4 года назад

    Awesome video... concepts are very clear.

  • @roothacks6864
    @roothacks6864 4 года назад

    I am very happy sir please make a whole series of it❤❤❤

  • @maxhouseman3129
    @maxhouseman3129 4 года назад +1

    Pop does not really delete it from memory. It only decreases the counter, but in raw data the element is still existing.

  • @BleedingDryTheHeart
    @BleedingDryTheHeart 4 года назад +1

    This is awesome , thank you Brad

  • @CoderArchive
    @CoderArchive 4 года назад

    awesome! data structures are important to know about like hash tables, I'm looking forward to more 💯

  • @alexandrodisla6285
    @alexandrodisla6285 4 года назад

    Data structure and Algo is very relevant in competitive programming. Big companies seems to need these skillsets. It makes you overall a better and efficient developer. For me data structure & algo + design patterns + all.i.dont.know.yet makes you write efficient program.

    • @adrian-4767
      @adrian-4767 4 года назад

      alexandro disla can all haitians speak French?

  • @smartydude2157
    @smartydude2157 4 года назад

    That's so awesome 😍 i think Actually my Law of Attraction has worked out.. I was daily searching for great whole algorithm series and finally got it 😊😊😀

  • @gihantharatnayake3411
    @gihantharatnayake3411 4 года назад

    Hey Brad. Pop doesnt actually remove the elements from the array.
    It looks correct cus the count value decreases. If you print the array at the end you will find all the elements are still there.

  • @tom.watkins
    @tom.watkins 4 года назад

    Great video. Only thing I was expecting was the pop method to reduce the size of the internal array

  • @captainmeme9476
    @captainmeme9476 4 года назад

    hope one day you are not going to left us , without telling even a goodbye , your are an inspiration for a lot of people who are struggling in their life , am living in a place where tech and programming stuff are impossible to learn and accecible only for extra-rich people , i had and i still have a lot of different problems in my life but with you guys (dev dd , web dev...) my vision about life has changed and am determined to do my best , hope one day we are going to meet and speak like friends .
    #devTips #thenewboston...........

  • @ogeobubu
    @ogeobubu 4 года назад

    Thank so much for this.
    Well explained and totally understandable. I hope you see this but this is kinda a reminder of the promise sir to make this an ongoing series.
    I look forward to seeing Queue, Binary Search Tree and others.
    Thanks in anticipation :-)

  • @arielspalter7425
    @arielspalter7425 4 года назад

    Awesome tutorial, thank you!

  • @nirtzezana627
    @nirtzezana627 4 года назад

    Keep it up with the Data structures, great!

  • @avi12
    @avi12 4 года назад +1

    In the .pop() method you forgot to modify the items stack

  • @TheBadFred
    @TheBadFred 4 года назад

    Is there a LIFO, a queue, a buffer, planned?

  • @CodingWithMrM
    @CodingWithMrM 3 года назад

    Thanks it's really helpful for me

  • @hardwired66
    @hardwired66 3 года назад

    datastructure content ❤️ from SEA.

  • @arjitamathur4718
    @arjitamathur4718 4 года назад

    Sir please teach all data structures and algorithms !
    I am a learner from *INDIA* . I really like your videos and the way you teach. It's really helpful sir . It's a request that please make a data structure series in which we get in depth knowledge of the course .Thankyou Sir .. Really grateful to u !

  • @diegosimonelli
    @diegosimonelli 3 года назад

    Is the data structure series out yet? Or you stopped doing them?

  • @shachaha
    @shachaha 4 года назад

    awesome as usual! I would totally love it to see more of that!! :D

  • @Mehedihasan-rahat
    @Mehedihasan-rahat 6 месяцев назад

    Very very smart job thanku❤

  • @sagarsuryawanshi8735
    @sagarsuryawanshi8735 2 года назад

    @Traversy Media Where is the link to full playlist of this course.

  • @magedhanafy9010
    @magedhanafy9010 4 года назад

    Yes, please do a video on proper testing

  • @MeTr1ckZUCSGO
    @MeTr1ckZUCSGO 4 года назад

    pop is not removing items from the stack, we just change 'count' pointer hiding the bug and potential memory leakage.

  • @nextrie
    @nextrie 4 года назад

    Oh yes! Are you going to use other languages like Python as well in your Data Structures series?

  • @credonduhura7121
    @credonduhura7121 4 года назад

    Thanks for starting this series Brad!! it's very important stuff to know as a programmer, as you mentionned. Can you please make a udemy course for algorithms and data structures

  • @valentin.berlin
    @valentin.berlin 4 года назад

    Thank you, Brad, very clear explanation. I think it's a great topic. In future videos, could you also include examples of some use cases for the structures you cover?

  • @thefather8362
    @thefather8362 4 года назад

    Hey Brad, any examples of when you would use this data structure?