Absolutely magnificent! Very well taught. Thank you so much!
@morisheldon35307 ай бұрын
As ppl pointed out, node.parent is still point to node, not the tmp we need to make node.parent to point tmp but without parent pointer in Node class, it's hard (need to find node.parent starting from root) let's say we use parent pointer too in the Node class, then the leftRotate method can be like this, hopefully public Node leftRotate(Node node) Node tmp = node.right; if tmp == null // 어쩌다 오른쪽 자식이 없는데 회전을 시도하게되는 경우를 다뤄줍니다 ---return node; node.right = tmp.left; if node.right != null // tmp에게서 null이 아닌 노드를 물려받음, 그 노드의 부모를 변경해줘야 함 ---node.right.parent = node; tmp.left = node; tmp.parent = node.parent; // tmp의 부모를 node의 부모로 변경합니다. null이어도 괜찮습니다 if node.parent != null // node.parent가 null이면 tmp가 root가 되므로 스킵해야합니다 ---if node.parent.left == node // node가 부모의 왼쪽 자식인지 확인, 주소 비교로 가능 ------node.parent.left = tmp; // node.parent가 기존의 node 대신 tmp를 가리킴 ---else ------node.parent.right = tmp; else // node.parent 가 null 이므로 root 입니다, root를 업데이트 해줍니다 ---root = tmp; node.parent = tmp; // 이제 node.parent를 tmp로 업데이트 해줘도 순서상 문제가 없습니다 return tmp; comment i wrote is in korean, sorry too lazy to translate hopefully this is correct and helpful to others watching this amazing course
@daleprather30263 жыл бұрын
Great content! You make this stuff much easier to understand.
@Play-Date-Care4 жыл бұрын
Many many thanks! You are an awesome professor!
@hemantparashar87817 жыл бұрын
There is a problem. In the code, parents of the nodes that are re-arranged or rotated are not updated.
@ricardoavilalegra67397 жыл бұрын
Great videos, thank you very much.
@皮凯鱼说的对7 жыл бұрын
Amazing, super helpful
@princeyadav80343 жыл бұрын
Great vedio
@kentkou18724 жыл бұрын
Thank you very much.
@huannguyentrong12494 жыл бұрын
ty
@aronpop14475 жыл бұрын
Set grandparents left child to temp right child..inst it set grandparent to temp right child..? I mean grandparebts left child is already having a right child which is null
@trerentr7 жыл бұрын
What if grant parent is not root and we dont have parent pointer, how do we point grand parent's parent to the new head?( in this case temp )
@trerentr7 жыл бұрын
just for left rotation and right rotation
@v3n4c0ding56 жыл бұрын
I think if temp.parent is None (py) then root = return variable.
@_paralaks_4 жыл бұрын
grandParent.parent == null means root so no problem. grandParent.parent != null means we can do: grandParent.parent.left or grandparent.parent.right = rotate(grandParent)