6. Binary Trees, Part 1

  Рет қаралды 162,163

MIT OpenCourseWare

MIT OpenCourseWare

Күн бұрын

Пікірлер: 79
@ParthPatel-vj2zv
@ParthPatel-vj2zv 3 жыл бұрын
0:00 intro 4:00 what is a binary tree 9:10 subtree, depth of a node, height of a node, height of a tree 16:24 traversal order of a tree 20:32 traversal operations 33:13 insert and delete operations 47:20 implementing a set with a tree (BST)
@shyamtripathi2097
@shyamtripathi2097 Жыл бұрын
Thank you. Where can we get the recitation (to see the python code)?
@dzmitry-lahoda
@dzmitry-lahoda 4 ай бұрын
deletion kzbin.info/www/bejne/bWfHmaedj9lmbqM
@nate716
@nate716 Ай бұрын
What strikes me is that these lectures are the exact same as the computer science lectures we get at my very low ranked public university. But the difference is that the students in the room have better GPA and accolades than most students in the country. We all learn the exact same things, but the difference is what we do with this knowledge. That’s what makes MIT different. Thank you for posting this for free. :))
@knowsomething-b8d
@knowsomething-b8d 2 жыл бұрын
He came wearing a root shirt. Legend
@Ayushr0129
@Ayushr0129 8 ай бұрын
Yeah, it’s now that I am realizing that 😂
@wisdomkhan
@wisdomkhan 3 жыл бұрын
Thank you very much MIT. Please do not ever stop this life changing work. Those who dream of studying in MIT can fulfil it here.
@stanfordy9104
@stanfordy9104 2 жыл бұрын
nerd
@xugeorge7030
@xugeorge7030 Жыл бұрын
@@stanfordy9104 says someone who literally has stanford in one's username
@flymykim
@flymykim Жыл бұрын
true, but im sure this signals some huge change to how the industry will operate. This knowledge, being taught with this much clarity, used to cost tens of thousands of dollars. it can only mean it no longer does...
@GaioSonase
@GaioSonase 5 ай бұрын
@@flymykim the very same knowledge was always available for pennies on the ivy league dollars. It's not really about the knowledge itself.
@GaioSonase
@GaioSonase 5 ай бұрын
@@flymykim What I am trying to say is that the same knowledge could always be found in any university and even outside of university. The true value isn't really in the knowledge--a library is more than enough for that--but the people, the instruction, and the environment.
@th2315
@th2315 2 жыл бұрын
Very engaging and informative class, I look through all the online sources, this is the only high-quality algorithm course that is free and python-based. I learned a lot from it! Loved it!
@anjanikumarjha209
@anjanikumarjha209 2 жыл бұрын
are there any data structures course of same quality please suggest
@sushanthreddy5513
@sushanthreddy5513 2 жыл бұрын
At 29:17, I think it should be "return node.parent" instead of "return node" as node.parent would then be the first parent with a left-child while moving up the tree.
@gokulakrishnancandassamy4995
@gokulakrishnancandassamy4995 Жыл бұрын
Exactly, even I thought the same! He even says that it is that parent that will be the successor!
@prashantsharma312
@prashantsharma312 3 жыл бұрын
Great lecture. I always had confusion about the successor - thanks for the clarification.
@biswanathsingh1991
@biswanathsingh1991 10 ай бұрын
Very interesting and educational course; after searching all internet resources, this is the only excellent, free, Python-based course on algorithms. It taught me a lot of things
@pif5023
@pif5023 2 жыл бұрын
Thank you for sharing this lesson!! As a self thought professional this really gave me ahas moment! For better or worse I was hired before I could dive deep into algos and these lessons are gold!
@tarunsinghyadav5477
@tarunsinghyadav5477 3 жыл бұрын
Thanks MIT for providing great content.
@ernesto8738
@ernesto8738 2 жыл бұрын
I know the comments here get melodramatic but seriously: thanks, it means a lot to have this available
@linonator
@linonator Жыл бұрын
These classes pay so many dividends. It’s just amazing!
@jaggis4914
@jaggis4914 3 жыл бұрын
Thanks MIT. Thank you Erik!
@aghahasaan
@aghahasaan 3 жыл бұрын
Thank you so much, what a great lecture, respect from Pakistan!
@suindude8149
@suindude8149 8 ай бұрын
The depth and the breadth first search would be the representation criteria for the data stored inside the memory thus the Information science has got a great evolution. The most efficient search criteria may be having the best case in case of a particular structure namely BFS would be a faster in time complexity than DFS. BFS could be implemented by using the any directional criteria using Stack as the structural unit.
@apuravmahajan283
@apuravmahajan283 5 күн бұрын
29:13, should it be return node.parent? i am confused anybody explain please
@krishviz485
@krishviz485 3 жыл бұрын
Can someone clarify "why insert_before and insert_after is required in BST ADT when insert operation takes care of inserting where it belongs to?"
@andriuscibas
@andriuscibas 2 жыл бұрын
Because, and that was mentioned in this lecture, the sub-roots can sometimes sort of copy the insert and create several records of the same value. In order to eliminate that possibiity, insert_bf and insert_af is used.
@charliezhou6514
@charliezhou6514 2 жыл бұрын
the leaf analogy is so funny
@mikhailkilianovski8024
@mikhailkilianovski8024 11 ай бұрын
🌳Could you provide a justification for why we need to 🔁swap 🔁values while doing deletion instead of just overwriting the value of a current node `A` with a value of node `B` ? We are going to delete🚮 `B` anyway, so why bother writing something there?
@lucifyer4486
@lucifyer4486 2 жыл бұрын
Thank you for uploading this lecture!
@madoben3294
@madoben3294 2 жыл бұрын
at 30:17 of the video. Aren't we supposed to return node.parent since that is the successor?
@paulluckner411
@paulluckner411 9 ай бұрын
I believe the given notation is not quite clear. While walking upwards we need to check if we are going up a left branch and simultaneously update our current node. If it was a left branch then return the updated/current node.
@originalgamer4962
@originalgamer4962 2 жыл бұрын
why did we not swapped a with d at (42.11-video) , that would be the leaf node and we could immediately remove the a
@helloworldcsofficial
@helloworldcsofficial 4 ай бұрын
I thought the edges in a binary tree are directional, one-way relationship (parent to child only). Right?
@hoze540
@hoze540 Жыл бұрын
43:42 isn't A's predessesor supposed to be b after being swapped with E?
@apuravmahajan283
@apuravmahajan283 5 күн бұрын
nah, left child comes first for every node
@mohammadsalehdehghanpour9856
@mohammadsalehdehghanpour9856 7 ай бұрын
Is it explained in previous lectures hiw to achieve O(1) for insert first with dynamic array?
@roros2512
@roros2512 3 жыл бұрын
I think he forgot to explain how to delete in the case if node.right, could anyone please explain this point? thanks! 47:30
@huzaifakhan_771
@huzaifakhan_771 2 жыл бұрын
He did explain it. In case of node.right, we swap the node item with its successor because it would be lower in the tree
@nikachachua5712
@nikachachua5712 2 жыл бұрын
can someone explain pls in dynamic arrays insert/delete_first takes O(1) a , but it have to shift all elements so how is that O(1)?
@mittunsudhahar634
@mittunsudhahar634 2 жыл бұрын
You can link another dynamic array to the front of the other dynamic array, and maintain both at the same time. One starts from index 0 and the other goes before 0. The details were mentioned in one of the previous lectures tho. Based on this you get insert/delete first in O(1) amortised time just like ins/del last in a regular dynamic array.
@ianholloway9493
@ianholloway9493 2 жыл бұрын
@@mittunsudhahar634 Do you mean like a circular array where you can define where the array starts so you can expand the array in both directions when needed.
@mittunsudhahar634
@mittunsudhahar634 2 жыл бұрын
@@ianholloway9493 Kind of a similar concept but nah I literally mean two dynamic arrays linked together, the second array allows for insertion/deletion at the front of the array, and every so often you need to rebuild the arrays to reorganise them but that happens few enough times that you can call it amortised O(1). They explain way better than I do in one of their videos.
@anonymitynone6957
@anonymitynone6957 2 жыл бұрын
@@ianholloway9493 I think Mittun Sudhahar says that for example, for an array A, if A[0] is the first but you need to insert a value before A[0], then you can define another array B, that B[i] represents A[-i-1], that like use B[0] to represent A[-1], but you should maintain both A and B. This is a method but seems didn't explain what nika chachua asked
@exlife9446
@exlife9446 2 жыл бұрын
so this is newer version of lecture of ?
@epicflails5471
@epicflails5471 2 жыл бұрын
Yo is it just me or does that chalk look super smooth to write with ???
@suhasdotcom
@suhasdotcom 2 жыл бұрын
@42:46 Hello Professor Demaine. With respect I want to ask that why don't we swap A and successor(A) (H in this case). It'd be much easier to remove that leaf.
@mayankdhiman5355
@mayankdhiman5355 3 жыл бұрын
this is where peter parker wanted to go for his graduation.
@bgspradeep
@bgspradeep 12 күн бұрын
very goood lecture
@RoseS-mf8ye
@RoseS-mf8ye 3 ай бұрын
41:04 delete
@jks2110
@jks2110 2 жыл бұрын
isnt the traversal result for the tree FDEBAC? as per inorder traversal
@paulluckner411
@paulluckner411 9 ай бұрын
No, it is FDBEAC. Note, B is before E, similar as A is before C.
@kunchasaikrishna
@kunchasaikrishna 3 жыл бұрын
I wonder why can't they use digital white board or with a projector for explanation than black board. Easy to use and explain
@fgfanta
@fgfanta 2 жыл бұрын
I find that the instructor writing on the blackboard while talking gives the perfect pacing. Digital stuff encourages the use of pre-made slides, and they kill pacing. The soft noise of the chalk also contributes to the pacing.
@pyrocrackermillenium675
@pyrocrackermillenium675 7 ай бұрын
I feel like it also demonstrates a useful skill to the students. Explaining from near-scratch is a useful skill for collaborating in environments without so much established theory.
@이택영-l9h
@이택영-l9h 2 жыл бұрын
Emotional damage for node A
@soonshin-sam-kwon
@soonshin-sam-kwon 2 жыл бұрын
Thanks a lot.💎🎓🔥💯
@kafychannel
@kafychannel Жыл бұрын
thanks a lot was extremely useful
@hoze540
@hoze540 Жыл бұрын
actually i get it now, G comes before B
@im-ls8tm
@im-ls8tm Жыл бұрын
1:04
@Anmol_Kamo
@Anmol_Kamo 3 жыл бұрын
boht hard
@angelsandemons
@angelsandemons 3 жыл бұрын
xD great lec
@Anmol_Kamo
@Anmol_Kamo 3 жыл бұрын
normie
@thinkGrey_
@thinkGrey_ 3 жыл бұрын
Thanks
@humanparaquat69
@humanparaquat69 2 жыл бұрын
What about the non-binary trees? You have to be inclusive
@ShredST
@ShredST 2 жыл бұрын
Extending a binary tree to having more than two children is pretty straight forward.
@humanparaquat69
@humanparaquat69 2 жыл бұрын
@@ShredST It was a joke
@edwardnjogu159
@edwardnjogu159 Жыл бұрын
wait until Twitter sees this
@glen9620
@glen9620 Жыл бұрын
@@edwardnjogu159 lmao
@yunoletmehaveaname
@yunoletmehaveaname Жыл бұрын
Gotta learn about them genderfluid trees
@majid_devops
@majid_devops 8 ай бұрын
"I'm just a leaf you know"
@NavinY5
@NavinY5 Жыл бұрын
Day 7 present
@gpullareddy-o7x
@gpullareddy-o7x Жыл бұрын
use Internal Pointer Variable
@hussienalsafi1149
@hussienalsafi1149 2 жыл бұрын
😊😊😊😊😊😊😊😊🇺🇸🇺🇸🇺🇸🇺🇸
@roni_castro
@roni_castro 4 ай бұрын
I might be dumb, because I don't understand almost nothing of these MIT lectures. They explain with very few practical or simulation examples, so it's hard to understand
@AmmarAsmro
@AmmarAsmro Ай бұрын
Take the prerequisite courses until 90% of the course is understandable. It is very well explained so I would work on your foundations . We all started in a similar place
7. Binary Trees, Part 2: AVL
54:09
MIT OpenCourseWare
Рет қаралды 74 М.
1. Algorithms and Computation
45:39
MIT OpenCourseWare
Рет қаралды 1,5 МЛН
黑天使被操控了#short #angel #clown
00:40
Super Beauty team
Рет қаралды 60 МЛН
How to treat Acne💉
00:31
ISSEI / いっせい
Рет қаралды 83 МЛН
VIP ACCESS
00:47
Natan por Aí
Рет қаралды 29 МЛН
Understanding B-Trees: The Data Structure Behind Modern Databases
12:39
2023 MIT Integration Bee - Finals
28:09
MIT Integration Bee
Рет қаралды 2,1 МЛН
Lecture 1: Algorithmic Thinking, Peak Finding
53:22
MIT OpenCourseWare
Рет қаралды 6 МЛН
2. Data Structures and Dynamic Arrays
50:18
MIT OpenCourseWare
Рет қаралды 547 М.
Learn Binary search trees in 20 minutes 🔍
20:25
Bro Code
Рет қаралды 194 М.
MIT Introduction to Deep Learning | 6.S191
1:09:58
Alexander Amini
Рет қаралды 780 М.
Lecture 6: AVL Trees, AVL Sort
51:59
MIT OpenCourseWare
Рет қаралды 673 М.
How to solve (almost) any binary tree coding problem
4:20
Inside code
Рет қаралды 194 М.