2. Data Structures and Dynamic Arrays

แชร์
ฝัง
  • เผยแพร่เมื่อ 7 ม.ค. 2025

ความคิดเห็น • 204

  • @pantheonCaspian
    @pantheonCaspian 2 ปีที่แล้ว +115

    This man's enthusiasm for algorithms is what I want in my life.

  • @ParthPatel-vj2zv
    @ParthPatel-vj2zv 3 ปีที่แล้ว +303

    0:00 : intro
    0:50 : interface vs data-structure
    5:50 : static sequences & static arrays
    16:50 : dynamic sequences & linked-list
    25:20 : static array vs linked-list
    34:25 : dynamic arrays (lists in python)
    46:27 : amortization

  • @domemvs
    @domemvs 3 ปีที่แล้ว +120

    Thanks to the MIT for making this available for free. This is a very selfless move. Amazing

  • @georgejetson9801
    @georgejetson9801 3 ปีที่แล้ว +59

    This is what passion looks like. I got my CS degrees at the first boom/bust cycle in the 80s. I've enjoyed everything about this career.

  • @unorandom3009
    @unorandom3009 3 ปีที่แล้ว +178

    I've been listening to this guy teaching algorithms for over 10 years seems his age algorithms is super efficient where his age is always constant O(1)

    • @factfinderchannel9965
      @factfinderchannel9965 3 ปีที่แล้ว +6

      It will be exponential time his age algorithm efficiency if you keep following his course for the next 20-30 years.

    • @michelealessandrini3421
      @michelealessandrini3421 3 ปีที่แล้ว +9

      Maybe it's amortized constant, one night he suddenly becomes old.

    • @unorandom3009
      @unorandom3009 3 ปีที่แล้ว +3

      @@michelealessandrini3421 exactly he look the same after ten years that's why it's constant O(1)

    • @OscarMartinez-nt6zn
      @OscarMartinez-nt6zn 2 ปีที่แล้ว +2

      @@unorandom3009 but with amortized someday all of a sudden he will need to grow and become O(N)

    • @primaryesthethicinstincts4832
      @primaryesthethicinstincts4832 ปีที่แล้ว +3

      You've been learning algorithms for 10 yrs??

  • @MrApolloIII
    @MrApolloIII 3 ปีที่แล้ว +44

    Shout out to the camera man! For panning to the information he’s referencing that we can’t see!

  • @sumandangol0286
    @sumandangol0286 11 หลายเดือนก่อน +4

    🎯 Key Takeaways for quick navigation:
    00:28 🧠 *Today's focus is on data structures, specifically sequences, sets, linked lists, and dynamic arrays.*
    01:27 🗂️ *Interface defines what to do; data structure defines how to do it. Data structures involve storing and manipulating data with specified operations.*
    02:51 🔄 *Two main interfaces: sets and sequences. Multiple data structures can solve the same problem, each with different advantages.*
    05:43 📊 *Static sequence interface includes build, length, iteration, get, and set operations. Focus on static arrays as a natural solution.*
    08:34 🧮 *Static array relies on the word RAM model, allowing constant time access. Memory allocation model assumes linear time for array creation.*
    17:04 ➕➖ *Dynamic sequence interface adds insert and delete operations. Introduces the concept of insert_at to maintain indexing consistency.*
    19:56 ⏮️⏭️ *Special cases like insert_first, insert_last, get_first, set_first, get_last, and set_last are introduced and can be more efficient to solve.*
    21:20 🔗 *Linked lists, composed of nodes with item and next fields, are introduced as a data structure to implement dynamic sequences.*
    23:17 📚 *Arrays and pointer-based data structures were discussed, highlighting the use of pointers as indices into the memory array.*
    25:33 ⏭️ *Dynamic sequence operations were explored on static arrays and linked lists, revealing the challenges of insertion at the beginning for both.*
    29:51 🔄 *Linked lists excel in insert and delete operations at the front but struggle with random access, making operations like get and set inefficient.*
    33:51 🔄 *The lecture introduces dynamic arrays, aiming to combine the advantages of linked lists and static arrays for efficient operations.*
    35:14 🧠 *Dynamic arrays relax the constraint that the array size equals the number of items, allowing for efficient insertions at the end in constant time.*
    40:12 📏 *The lecture discusses resizing strategies for dynamic arrays, emphasizing the importance of choosing a constant factor larger than 1 to avoid frequent resizes.*
    43:31 ⏱️ *The amortized analysis of resizing dynamic arrays is explained, revealing a geometric series summing to roughly linear time, emphasizing the efficiency of the strategy.*
    45:51 🔄 *Geometric series are dominated by the last term, allowing for simplified analysis using theta notation, such as theta of the last term like 2 to the log n, which is theta n.*
    46:45 📈 *Amortization is introduced as a way to analyze the average time of operations over a sequence, considering that while some operations may be expensive, they are balanced by cheaper ones, resulting in amortized constant time for certain operations.*
    47:42 📊 *Amortization is described as an averaging concept over a sequence of operations, allowing for high-cost operations like resizing to be distributed across the cheaper ones, achieving almost constant time on average.*
    49:38 🔄 *Dynamic arrays achieve constant amortized time for operations like insert_last and maintain constant time for get_at and set_at, showcasing a balance between the strengths of arrays and linked lists.*
    Made with HARPA AI

  • @RurikLoderr
    @RurikLoderr 2 ปีที่แล้ว +38

    I've been programming on and off since high school (class of 2003) and recently decided to catch back up with the MIT OpenCourseWare lectures... 10:05 to 11:17 is the first time I've ever had zero indexing explained in a way that just makes it clear that's why it's being done. Never in my entire life had anyone just said it was an offset in memory and I'm kind of disappointed. That single simple fact of something I thought I knew well just made a whole lot of memory addressing knowledge grok immediately.

  • @shankar7435
    @shankar7435 ปีที่แล้ว +14

    Never got a chance to listen to lectures at IIT. I am lucky enough to learn from even quality lectures. Thanks to MIT.

    • @ayushbhardwaj2708
      @ayushbhardwaj2708 9 หลายเดือนก่อน

      th-cam.com/play/PLBF3763AF2E1C572F.html&si=idwQNxg_A75C6hdz
      Even IITs have a combined open courseware.

  • @yeboahdominic1896
    @yeboahdominic1896 3 ปีที่แล้ว +91

    In fact I have been watching a lot of tutorials from this channel and this professor is one of my favorites.

    • @FlexGC
      @FlexGC 3 ปีที่แล้ว +13

      Yes he's great. He is / was also a prodigy. I think he got his bachelors when he was still a teen.

    • @noelcovarrubias7490
      @noelcovarrubias7490 3 ปีที่แล้ว +5

      @@FlexGC no way? O:

    • @MufaddalHakim
      @MufaddalHakim 2 ปีที่แล้ว +10

      @@noelcovarrubias7490 He became a professor at MIT when he was 20

    • @nadiatalaat3561
      @nadiatalaat3561 ปีที่แล้ว

      @@FlexGC which programming language he explain with ?

  • @shankar7435
    @shankar7435 ปีที่แล้ว +1

    I experienced the fact that when you listen to passionate people, you would love to become passionate. This is the ultimate benefit I am taking away right now from this lecture.

  • @HulkRemade
    @HulkRemade 2 ปีที่แล้ว +4

    I love the way this guy writes on the board. It's so satisfying.

  • @dcpugh
    @dcpugh 2 ปีที่แล้ว +31

    Awesome lecture! A treat to hear a talk on basics by such an accomplished computer scientist!

  • @ssaadhussain902
    @ssaadhussain902 3 ปีที่แล้ว +37

    This lecture was so brilliant. The concepts are crystal clear.

  • @SphereofTime
    @SphereofTime หลายเดือนก่อน

    1:27 interface specify what data
    ADT
    Ds tells how
    3:17 what you want to do
    How
    Ops
    Build. Get. Set

  • @hanyanglee9018
    @hanyanglee9018 2 ปีที่แล้ว +5

    Oh, oh, I'm so happy. Years ago I downloaded the old videos and tried watching on metros. I quit at around 1/3. It was too hard for me. Now I'm back. Let me try learning this again.

  • @1ncandescence737
    @1ncandescence737 3 ปีที่แล้ว +26

    Oh my! Was wondering when we are getting a refreshed version of 6.006!

  • @diannadimambro2188
    @diannadimambro2188 ปีที่แล้ว +3

    saw his 2005 and now his 2020. such a great professor!

  • @otmane09
    @otmane09 3 ปีที่แล้ว +3

    Thank you so much for not enabling ads in this videos

  • @igor-sukharev
    @igor-sukharev 2 ปีที่แล้ว +2

    There is difference between ADT (Abstract Data Type) and DS (Data Structure).
    ADT is the specification. It answers questions "what data can be stored" and "what can I do with them".
    DS is the concrete implementation of ADT. DS specifies how data is stored (its layout) and what kind of algorithms process them.
    Single ADT (array, e.g.) can be satisfied using several DS (linked list, static array, etc.)

    • @igor-sukharev
      @igor-sukharev 2 ปีที่แล้ว

      There are 2 main ADT: Set and Sequence.
      Set does not allow to receive an item via index; Sequence does. (what can I do with them?)
      Notice that the absence of indexes entails the inability to distinguish between two identical elements.
      Set does not allow to store dublicates; Sequence does. (what data can be stored?)

    • @igor-sukharev
      @igor-sukharev 2 ปีที่แล้ว

      There are 2 main approaches how to construct DS: using an array or using pointers.
      In the array, data store in continuous part of memory.
      In the pointer-based approach, each item has links to some of others; physical addresses of items is generally unknown.

    • @igor-sukharev
      @igor-sukharev 2 ปีที่แล้ว

      Static Sequence Interface (SSI) is an ADT, the variant of the Sequence.
      This interface maintain fixed number (aka length) of items x0, x1, ..., x(n-1), but these items are able to be rewritten.
      The list of operations of the Static Sequence Interface:
      build(X): make new DS. X is the something that may yield items one by one.
      len(): returns the n.
      iter_seq(): outputs the items in its order.
      get_at(i): returns the item number i.
      set_at(i, x): set x as the item number i.

    • @igor-sukharev
      @igor-sukharev 2 ปีที่แล้ว

      Static Array is a DS, an obvious, natural way to implement the Static Sequence Interface
      Here and forth, we assume that our model of computation contains RAM with w-bit cells, where w=length of the word, group of bits the processor can to process per one step.
      The access to each cell takes equal time.
      Also, our model allows to allocate n sequential words in RAM in a Theta(n) time.
      Static Array is the consecutive, continuous part of RAM with constant length.
      array[0] = memory[address(array)], array[i] = memory[address(array) + i] for i from 0 to n-1.
      len, get_at, set_at operations have Theta(1) time complexity
      build, iter_seq have Theta(n).

    • @igor-sukharev
      @igor-sukharev 2 ปีที่แล้ว

      Dynamic Sequence Interface (SSI) is an ADT, the variant of the Sequence.
      This interface maintain number (aka length) of items x0, x1, ..., x(n-1).
      The list of operations of the Dynamic Sequence Interface:
      [all of SSI operations]
      insert(x, i): transforms the sequence to y0, ..., y(n), where y0 = x0, ..., y(i-1) = x(i-1), y(i) = x, y(i+1) = x(i), ..., y(n) = x(n-1).
      delete_at(i): transforms the sequence to y0, ..., y(n-2), where y0 = x0, ..., y(i-1) = x(i-1), y(i) = x(i+1), ..., y(n-2) = x(n-1).
      So-called convenient operations insert/delere_first/last may be considered an implemented via special algorithms.

  • @Nmdt-d
    @Nmdt-d 3 ปีที่แล้ว +10

    He is very energetic. I have now great teachers!

  • @TildaAzrisk
    @TildaAzrisk 6 หลายเดือนก่อน

    I find 39:30 amusing in that im imagining the blackboard area as the array being talked about.
    The blackbored is of static size however, so to store new elements old elements have to be overwritten. Yet, many of the points being made do still apply.

  • @SalesforceUSA
    @SalesforceUSA 3 ปีที่แล้ว +7

    I don't know why TH-cam recommended this to me, but I stayed for the whole lecture.,,

  • @harshitarawat8941
    @harshitarawat8941 2 ปีที่แล้ว

    __sizeof__ > 1 Len : 48 size, any addition > +8
    with append resize at : 1st , +4, +4, +8

  • @wpontius4355
    @wpontius4355 2 ปีที่แล้ว +1

    Working with Python and C++ counting from 0 to n, 0 would be your 1, 1 would be your 2...etc. His counting would give you n+1 (0,1,2,3,4), you want n-1 (0,1,2,3).

  • @nehaliacharya7257
    @nehaliacharya7257 3 ปีที่แล้ว +14

    I think cracking a FAANG company will become a reality very soon. Thank you so much @MIT for these brilliant lectures.

    • @andiuptown1711
      @andiuptown1711 11 หลายเดือนก่อน +2

      Update? 👀

    • @MD.JAHIDULISLAM-w8w
      @MD.JAHIDULISLAM-w8w 8 หลายเดือนก่อน

      update please...

    • @andiuptown1711
      @andiuptown1711 8 หลายเดือนก่อน +1

      @@MD.JAHIDULISLAM-w8w *They flipping burgers somewhere 🗿*

    • @dibyajyoti_mansingh
      @dibyajyoti_mansingh หลายเดือนก่อน

      She's working @Deloitte USI, OC

  • @vam8775
    @vam8775 ปีที่แล้ว +2

    Knowledge Heavy Playlist... 💥 Every computer science student fav track thanks to MIT Ocw

  • @tetelim4428
    @tetelim4428 3 ปีที่แล้ว +1

    I really love Erik's style, so charmmmming

  • @Amir-w4l
    @Amir-w4l ปีที่แล้ว +2

    It is brilliant, I Love this method of learning ,thanks for MIT.

  • @programming5542
    @programming5542 3 ปีที่แล้ว +72

    please do it for 6.046 and 6.854 the algorithm trilogy by the way good to see you pro eric my lockdown i spend time with your course 6.006 6.046 and the advance data structure and in the last lecure online algorithms . please mit ocw it is my request

    • @NazriB
      @NazriB 3 ปีที่แล้ว

      Lies again? Meds DarkX

  • @atharvsingh6901
    @atharvsingh6901 ปีที่แล้ว +3

    Finally I'm a student at MIT😊

  • @quebrandomitos5910
    @quebrandomitos5910 หลายเดือนก่อน

    I very much doubt that anyone not already into programming is able to follow those classes by sheer will.

    • @videofountain
      @videofountain 13 วันที่ผ่านมา

      MIT website has the whole course, perhaps even prerequisite courses and books, additional materials. The on campus experience would have more foundation. Free additional materials are available from MIT. The students can communicate with each other on campus. There are so many free and low cost choices for Algorithm information. I agree that people with a few years of experience could benefit from review.

  • @DrJ3k4lMrH4d3
    @DrJ3k4lMrH4d3 ปีที่แล้ว +1

    I’m glad I saw this video. Thanks MIT for this. I just went thru algs and data structures and I think this is better than the one that I took.

  • @y2k898
    @y2k898 2 ปีที่แล้ว +3

    High quality free information, still useful after I working 10+ years

  • @tomoki-v6o
    @tomoki-v6o 3 ปีที่แล้ว +4

    his series on dynamic programming were great

  • @asamat404
    @asamat404 5 หลายเดือนก่อน

    9:20 Modern computers (x86, x64) are byte-addressable, not w-bit (32 or 64). There is misinformation about word size and byte addressing, at least for Intel/AMD CPU

  • @chiro5533
    @chiro5533 2 ปีที่แล้ว +3

    Thanks MIT for this open Course, amazing!

  • @abi69169
    @abi69169 3 หลายเดือนก่อน +1

    bro completed his PhD at the University of Waterloo by the time he was 20 years old.. no doubt he is a prodigy

  • @goldibollocks
    @goldibollocks 2 ปีที่แล้ว +1

    When you know you’ll be needing lots more memory later in your program: See you later, allocator

  • @SphereofTime
    @SphereofTime 3 หลายเดือนก่อน

    0:35 sequence set linkedlist dynamic arrays

  • @playme1354
    @playme1354 3 ปีที่แล้ว +4

    If you care to know, I just attended MIT. Thanks to TH-cam. 🥳🥳

  • @张心怡-s1v
    @张心怡-s1v 3 ปีที่แล้ว +2

    WOW! I HOPE I CAN WATCH THIS ALL! AND COMPLETE THE COURESE

  • @soyciro4623
    @soyciro4623 3 ปีที่แล้ว +9

    The instructor goes so fast! I can't actually get the idea or the theory. It looks like I should have a prior knowledge.
    Thank you for the content, though.
    It's really appreciated.

    • @iagobarretoc8194
      @iagobarretoc8194 3 ปีที่แล้ว

      my native language is not english but actually I did understand a lot from this. You can always rewatch, to understand more. Also to see/hear things you didnt notice previously

    • @SuperOnlyP
      @SuperOnlyP 3 ปีที่แล้ว

      this will help: th-cam.com/video/2T-A_GFuoTo/w-d-xo.html .
      Here is the whole list for the course: th-cam.com/play/PLhQjrBD2T382_R182iC2gNZI9HzWFMC_8.html to have some basic idea how to use pointer in c.
      ideally, you need to manage the memory block in ram to create your own data structure. You can allocate memory statically or dynamically.

    • @mytech6779
      @mytech6779 2 ปีที่แล้ว

      Yes. Many colleges seem to list prerequisites only as a way to make more money on tuition costs. Example, my local college requires an introduction to CS class before all other CS classes, but then they waste time in the following classes to duplicate all of the lessons in the introduction class. They also require english 101 without regard for score on your placement test, mainly to give money to the English department, while in math you may skip to the level of your test score. )
      MIT is different, when they list a prerequisite for a class it is because the class is truly designed with the assumption of specific existing knowledge. I ignored this one time and I needed to take an emergency class in calculus on the side so that I could keep up with my primary class.

  • @deletedaccount2580
    @deletedaccount2580 3 ปีที่แล้ว +4

    I am fan of this genius guy ,Eric 🙏🙏

  • @iEuno1
    @iEuno1 3 ปีที่แล้ว +4

    I learned that in 1992 and that is how I design my database systems .

    • @georgejetson9801
      @georgejetson9801 3 ปีที่แล้ว +2

      1980 here. :)

    • @iEuno1
      @iEuno1 3 ปีที่แล้ว +2

      @@georgejetson9801 Very good, I was in secondary 1 in 1980, when I learned Technical Drafting skills, which I used for my flowcharting and other diagrams designs in 1992 to this day. I scored 100% on it then.

  • @enisten
    @enisten 3 ปีที่แล้ว +8

    Erik Da Man!

  • @dugwtf
    @dugwtf ปีที่แล้ว +3

    unusually good handwriting for a male teacher

  • @offYears
    @offYears 18 วันที่ผ่านมา

    Took a while to understand that Word-RAM model is w-bit addressable _as well_ as w-bit worded!

  • @hadesunseen6388
    @hadesunseen6388 ปีที่แล้ว

    thank you for sharing such awesome content, its a real help for people like me who cant afford such higher studies

  • @baigsab748
    @baigsab748 ปีที่แล้ว

    Thanks for providing such awesome opportunity for learning

  • @hunternoah95
    @hunternoah95 3 ปีที่แล้ว +3

    The GOAT is back!

  • @shivamjalotra7919
    @shivamjalotra7919 3 ปีที่แล้ว +1

    My man is back.

  • @HikikomoriDev
    @HikikomoriDev 10 หลายเดือนก่อน +1

    I like the colour coding here.

  • @mingx009
    @mingx009 3 ปีที่แล้ว +4

    So great lecture in really giving you why and how, not just a bunch of hows. One question: delete_last() of array seems to me to only take O(1) constant time if choose to do so. I understand insert_last(x) would take O(n) time as a new array has to be created and copy all old elements (and inserted x) to the new array. But deleting the last one would still maintain the old array untouched for the first n-1 elements, and what only needs to be done is to update the len(static array) now to be n-1. Do I miss anything?

    • @saararamzy8045
      @saararamzy8045 3 ปีที่แล้ว +1

      Even I have the same question!

    • @OscarMartinez-nt6zn
      @OscarMartinez-nt6zn 2 ปีที่แล้ว +9

      In min 27:00 to 28:00 he explained this, but to sum it up basically though it seems like a O(1) operation it's not because a static array has a fix length and if you remove the last element then you are changing the space of memory that you were assigned meaning that the computer has to reallocate the memory to satisfy the new length of your array for that reason it's not convenient to use a static array for dynamic operations.

  • @AvoidMissteps
    @AvoidMissteps 3 ปีที่แล้ว +7

    Great lecture. Thanks!

  • @sirius7584
    @sirius7584 3 ปีที่แล้ว

    동적 배열
    - Relaxation of a contraint in size.
    - the size of an array is theta(n)

  • @SphereofTime
    @SphereofTime 3 หลายเดือนก่อน

    8:01 python list array

  • @willbdev
    @willbdev 8 หลายเดือนก่อน

    Thank you. I love this course.

  • @UmangPatel
    @UmangPatel 3 ปีที่แล้ว +1

    gifoyle is now a lecturer at mit

  • @rishiravi7312
    @rishiravi7312 3 ปีที่แล้ว +3

    thank you very much sir for wonderful teaching

  • @thehvhnk
    @thehvhnk 3 ปีที่แล้ว +1

    Erik in the house !!!

  • @boiledpotatos4828
    @boiledpotatos4828 3 ปีที่แล้ว

    this is actually fun to watch

  • @johnphamlore8073
    @johnphamlore8073 ปีที่แล้ว +1

    Thank you MIT for your generosity. On a side note, is it still true that there is a special thick chalk great for fast writing on boards that Professor Demaine seems to be using that is no longer made and needs to be hoarded?

    • @mitocw
      @mitocw  ปีที่แล้ว +2

      No need to hoard... the chalk is still available. It is known as either jumbo chalk or railroad chalk (used to mark boxcars).

  • @musaxebd
    @musaxebd 2 ปีที่แล้ว +2

    What are the prerequisite for this course. I found the concept very hard to understand. Fyi, i am doing java programming and have basic knowledge of programming.

    • @surfingcipher1059
      @surfingcipher1059 ปีที่แล้ว +2

      Sequence and series, descrite structures

  • @dawkosvk
    @dawkosvk ปีที่แล้ว +1

    Drunk as fuck and watched this whole video....for sure I'll remember something out of this hahahah

  • @random-0
    @random-0 ปีที่แล้ว +1

    Amazing, great lecture

  • @sharvyahmed
    @sharvyahmed 2 ปีที่แล้ว +2

    Brilliant lecture 👍🏻

  • @factfinderchannel9965
    @factfinderchannel9965 3 ปีที่แล้ว +2

    Great intro to computational complexity

  • @amo3838
    @amo3838 3 ปีที่แล้ว +7

    I looked for so many ways to start in programming ans find my self in this course. I love the enthusiasm. I hope to work through this class. Does someone has recommondations for me where I can train myself to become a programmer? Where I can do basic stuff?

    • @mitocw
      @mitocw  3 ปีที่แล้ว +18

      There are many great resources to learn programming. From our materials, we recommend you start with MIT 6.0001 Introduction to Computer Science and Programming in Python: ocw.mit.edu/6-0001F16. There is an edx version starting January 26: www.edx.org/course/introduction-to-computer-science-and-programming-7

    • @amo3838
      @amo3838 3 ปีที่แล้ว +3

      @@mitocw I thank you soooo much.

    • @alb12345672
      @alb12345672 3 ปีที่แล้ว +8

      I am programming since a teen in the 80s and there were no online resources back then. You had to be really motivated and push yourself to get books from bookstores and libraries. I have taught programming too. Best advice I can give you is to take an idea and start building it. Every time you hit a problem, research a solution. Yes, you need a certain baseline of knowledge, but don't spend years on that before starting to build something. All the school in the world is useless unless you can create something useful in code.

    • @rounakpatra2210
      @rounakpatra2210 2 ปีที่แล้ว +1

      @@mitocw Is there any difference between 6.0001(YT) and edx Version?

  • @adventurer2395
    @adventurer2395 2 ปีที่แล้ว

    The real epiphany comes at 40:00

  • @labeeb_ibrahim
    @labeeb_ibrahim 2 ปีที่แล้ว +1

    Has anyone got a ZIP of all the lecture notes? I usually found it on MIT OCW website. But not for this one.

  • @allandogreat
    @allandogreat 3 ปีที่แล้ว

    Best algorithm in the world

  • @stevesmith2553
    @stevesmith2553 3 ปีที่แล้ว

    array start with - zero , one etc

  • @stevesmith2553
    @stevesmith2553 3 ปีที่แล้ว +1

    do a two dim array

  • @matthewcao8514
    @matthewcao8514 ปีที่แล้ว

    Why is the time complexity for linked list for insert_last(x) and delete_last(x) linear? Shouldn't it be constant since we are able to access the tail?

    • @guitsgarcia5446
      @guitsgarcia5446 ปีที่แล้ว +2

      you don't store the tail on regular linked lists.
      Storing the tail is considered an "augmentation", and does reduce insert_last(x) to linear.
      delete_last(x) isn't so easy as you would need to fetch the second-to-last and update its pointer to null I think, therefore you would also need to go through the whole linked list.
      Doubly linked lists might solve this by storing tail on every element (see 32:34).

  • @addmuu
    @addmuu 3 ปีที่แล้ว +2

    44:45 wow that's nice

  • @michelealessandrini3421
    @michelealessandrini3421 3 ปีที่แล้ว +2

    Excuse me, I'm not native English, what's that "recitation" class they sometimes talk about?

    • @mitocw
      @mitocw  3 ปีที่แล้ว +6

      The purpose of the recitations is to expand upon course materials covered in lecture and allow students to practice working with the material in an interactive setting.

    • @AhmedGamal-xi3vj
      @AhmedGamal-xi3vj 3 ปีที่แล้ว

      @@mitocw Where to find the recitations classes?

    • @mitocw
      @mitocw  3 ปีที่แล้ว

      Here is the playlist for the series: th-cam.com/play/PLUl4u3cNGP63EdVPNLG3ToM6LaEUuStEY.html. The ones labeled problem sessions are the recitations. See the course on MIT OpenCourseWare for more info and materials (Lecture notes, recitation notes, problem sets, etc.) at: ocw.mit.edu/6-006S20. Best wishes on your studies!

  • @catrinacraft
    @catrinacraft 2 ปีที่แล้ว

    They're all in a classroom in Spring 2020? The university must've stayed open!

  • @kostagacinovic
    @kostagacinovic ปีที่แล้ว

    As it turns out, learning C before this was worth it

  • @thealchemist9781
    @thealchemist9781 2 ปีที่แล้ว

    1.Apa yang ingin kamu lakukan dan bagaimana cara melakukannya

  • @hopetembo6820
    @hopetembo6820 ปีที่แล้ว +1

    It made so much sense daummm😮

  • @AnkitMishra-hd5uu
    @AnkitMishra-hd5uu 3 ปีที่แล้ว +1

    Where I will get full video of this guys

  • @marcelsantee1809
    @marcelsantee1809 3 ปีที่แล้ว +1

    Why is len() constant time? Is it computed in an attribute along the build()?

    • @muhammadzeeshan303
      @muhammadzeeshan303 3 ปีที่แล้ว +1

      Constant time is used to measure the efficiency of the operation len(). It will take a constant amount of time to find the length of any nth item.

    • @muhammadzeeshan303
      @muhammadzeeshan303 3 ปีที่แล้ว

      And no build() is linear time not constant

    • @aa-hf7hd
      @aa-hf7hd 2 ปีที่แล้ว +1

      pretty late but yeah it's an attribute (idk if it's computed in build() though).
      python's len() will return a variable that gives the size of whatever object len() is called on, and that is an O(1) operation
      so python has to maintain that size variable as it updates, which is (some) overhead

    • @marcelsantee1809
      @marcelsantee1809 2 ปีที่แล้ว

      @@aa-hf7hd I figured out myself in the meantime. But this is explanation is great for future readers, thank you!

  • @IIGrudge
    @IIGrudge 2 ปีที่แล้ว

    I don't understand why word >= log(n)

  • @nishikanttayade7446
    @nishikanttayade7446 3 ปีที่แล้ว +1

    Post malone teaching DS and Algo, hell yeah!!

  • @wingsonthebus
    @wingsonthebus 3 ปีที่แล้ว +1

    I hereby slap my brain for every bad thought it’s ever had about Prof. Demaine. This is peak American: aware, unpretentious, brilliant!
    also this is uncalled for but screw it the world is ending he has a sweet fashion sense
    🤘😤

  • @basicsOfCode
    @basicsOfCode 3 ปีที่แล้ว

    Publish other lectures too.. Pls

  • @localizersss
    @localizersss 2 ปีที่แล้ว

    Thanks you from Cambodia

  • @ramyadogiparthi8069
    @ramyadogiparthi8069 7 ชั่วโมงที่ผ่านมา

    Brother can anyone share lecture notes
    please

  • @tzachs_
    @tzachs_ 3 ปีที่แล้ว +2

    MIT..Please provide course vidoes of Principles of macroeconomics and Intermediate microeconomic theory.

  • @Mikasks
    @Mikasks 3 ปีที่แล้ว

    16:11 “Download more RAM”

  • @pranki2254
    @pranki2254 3 ปีที่แล้ว

    What about the operation cost for inserting_first() for the dynamic arrays (Python lists)?

    • @h.kubilay6160
      @h.kubilay6160 3 ปีที่แล้ว +2

      o(n) because re index it. language does not matter.

  • @kritgrover
    @kritgrover 3 ปีที่แล้ว +1

    Great content!

  • @kubamilcarz
    @kubamilcarz 2 ปีที่แล้ว

    thank you for doing that for free

  • @jackmiller9829
    @jackmiller9829 2 ปีที่แล้ว +1

    nice course

  • @chrislee5044
    @chrislee5044 2 ปีที่แล้ว

    40:46 lol, Jason my guy

  • @rajnishkushx
    @rajnishkushx ปีที่แล้ว

    Insert last in static array? Why O(n)?

    • @llll-dj8rn
      @llll-dj8rn ปีที่แล้ว

      because the way you build a static array is by allocating a fixed size of memory, say you allocated 7 blocks of the memory, and suppose your static array will be like that A = [1,2,3,4,5,6,7], now what if you need to add new one element to your existing array? no you can't, because as i've said you've allocated a specific size of the memory (may the eighth block of the old sequence is not available ), so now i have to allocate a new sequence of the memory that can store my new "8 element array".

  • @sbk-po3jf
    @sbk-po3jf 2 ปีที่แล้ว

    thanks to MIT QAQ

  • @alicehuang8898
    @alicehuang8898 3 ปีที่แล้ว

    what is the book he mentioned to refer to by the end? Can someone tell me the name? Thx

    • @mannyknowles
      @mannyknowles 3 ปีที่แล้ว

      Not sure but most likely this one: mitpress.mit.edu/books/introduction-algorithms-third-edition

    • @tungo7941
      @tungo7941 3 ปีที่แล้ว +1

      It's called CLRS, which stands for the name of the 4 authors. The exact name of this book is "introduction to algorithms"

    • @mannyknowles
      @mannyknowles 3 ปีที่แล้ว +2

      So it is the book in the link I provided. Thanks for confirming.

  • @Juan-dc6yf
    @Juan-dc6yf ปีที่แล้ว

    Why camera guy follow him and not show the board at once smh