Principle of Optimality - Dynamic Programming

  Рет қаралды 209,512

CSBreakdown

CSBreakdown

Күн бұрын

Пікірлер: 71
@---ml4jd
@---ml4jd 7 жыл бұрын
We have a graduation project and we have a graph and want to find the optimal path. You saved us from reading lots of dull pages in 10 min. Thank you bro.
@---ml4jd
@---ml4jd 7 жыл бұрын
Omar Bin Salamah|| it involves that.
@leixia6415
@leixia6415 6 жыл бұрын
So if you take a glimpse of how Greedy and DP differs, the most noticeable feature is that Greedy is forward processing the question while DP appears to be backward propagation, though this stems from finding the optimal substructure.
@christiansakai
@christiansakai 7 жыл бұрын
I love these series, you should definitely make more. There aren't that many good tutorials on the internet about CS
@NytronX
@NytronX 6 жыл бұрын
5:10: The proof is so awkwardly trivial that it is hard to wrap my head around, lol.
@fqwixhg
@fqwixhg 8 жыл бұрын
Great video! You made this much easier to understand than my textbook
@nolannova9008
@nolannova9008 3 жыл бұрын
instaBlaster
@ahinst
@ahinst Жыл бұрын
Great video! helping college student like me who's just confused why the lecturer explained this so looooong then you just explained it in less than 10 minutes mksieee pak, saya g ngangong waktu matkul RO. pdhl deadline besok t__T
@khailai5204
@khailai5204 4 жыл бұрын
Very nice explanation!
@arunsatyarth9097
@arunsatyarth9097 8 жыл бұрын
Was that the correct way to prove it? It sounded like "Prove A is the killer. Imagine B is the killer. but it is not possible because we already stated that A is the killer. So B cannot be the killer."
@ivanreii
@ivanreii 7 жыл бұрын
I know it's old but.. In proof by induction, we can assume that a proposition P(k) is true, as long as k
@shibasissengupta1154
@shibasissengupta1154 7 жыл бұрын
hahaha...
@RelaxingSerbian
@RelaxingSerbian 6 жыл бұрын
The proof was not that a chosen solution is optimal, but that an optimal solution cannot be made out of non-optimal subsolutions.
@vic91020
@vic91020 4 жыл бұрын
Not exactly... Induction is not a circular argument, though I do not think iwas well explained. The essence of induction is: -We Know it works for n=0 (or the number you want to start with) -Prove that, if it works for a given number N, then works for n+1 Now you know it works for 1, and for 2, and for 3... Example: prove any number multiplied by 0 is 0 We know 0*1 = 0 if 0*n = 0, then 0*(n+1)=0*n+0*1=0+0=0 It is true for n=1, so it works for n=2 Since it is true for n=2, then it is true forn n=3 Since it is true for n=3, then it is true forn n=4 You have proven n*0 = 0 for any natural number Note: I think there is a proof from the definition of number that says you can extend this to all numbers, and it is needed since, though it is ombvious, you can only entend this reasoning up to a certain number if you use a finite number of steps (in our case, up to n = 4), so yo need the iduction theorem
@hydraslair4723
@hydraslair4723 Жыл бұрын
Nah. I had the same issue, but then I reflected on it a bit more. It all hinges on the fact that the optimal solution's cost is the sum of the costs of its parts. If the first half of the optimal path isn't optimal, then we could find a different sub -path which is optimal. But then the new sub-path plus the rest of the optimal path would give you a new solution, which would be better than the optimal path. In logical terms: "(Path is optimal) is true" "If not (sub-path is optimal) then not (path is optimal)" "Therefore, (sub-path is optimal) is true" With the middle sentence hinging on the fact that the optimal solution is sum of its sub-paths. Otherwise the implication cannot be made.
@amite.1878
@amite.1878 6 жыл бұрын
All the comments here saying this proof is "nonsense" - it's not! It may look weird and confusing the first time you see this kind of proof, so pay attention and try to follow: Think of it as if we're given AS A FACT that the route named R from origin city 'a' to destination city 'j' is the shortest. We're not trying to prove that. It's a given fact! Now what we actually want to prove is that any sub-route inside R (for example from 'a' to some midpoint 'k' that is located between 'a' and 'j') would ALSO be the shortest route to that midpoint. And why is that?? Because if there would exist a different route from 'a' to 'k' that is shorter, then you could also use it to improve R and reach faster to the final destination 'j'. But that's a contradiction to the GIVEN FACT that we have in the first place (that R is already the shortest). Thus you prove that any sub-path within a given shortest path, is ALSO a shortest path....
@fmartin59
@fmartin59 6 жыл бұрын
Brilliant comment. Helped me appreciate the proof better.
@asifnaqshi
@asifnaqshi 5 жыл бұрын
Awesome !!! Rightly explained !!! Thanks Helped me to better understand !!!
@johndubchak
@johndubchak 4 жыл бұрын
Excellently done. Well worth the simple time investment involved.
@7810
@7810 4 жыл бұрын
The explanation is quite clear. Thanks!
@lisa8768
@lisa8768 7 жыл бұрын
Good video. Explicit and easy to understand!
@Rousnay
@Rousnay 6 жыл бұрын
Excellent explanation!
@mradulgupta9626
@mradulgupta9626 7 жыл бұрын
Simplest explanation. Thank you very much
@why-ak
@why-ak 8 жыл бұрын
great job done brother really loved all your videos . Please make another video for other greedy algorithms and optimal binary search tree!
@arturogallobalma4621
@arturogallobalma4621 8 жыл бұрын
Ci sono 3 soluzioni: 1) A-D-F-I-J = 3+1+3+4 = 11 2) A-D-E-H-J = 3+4+1+3 = 11 3) A-C-E-H-J = 4+3+1+3 = 11
@navam23
@navam23 5 жыл бұрын
Exactly! And it wasn't actually explained why / how these similar solutions are derived...
@peksn
@peksn 3 жыл бұрын
@@navam23 It is because all nodes on any level are connected to ALL the nodes in the next/previous level, thus the algorythim will just take whatever the minimum one is the first, and roll with that.
@sau002
@sau002 5 жыл бұрын
Nicely explained
@saidelbiev5326
@saidelbiev5326 6 жыл бұрын
I read many comments that the proof doesn't make sense. It does in fact. The statement to be proved was: R(a.j) is shortest path from a to j IF R(a.k) is shortest path from a to k . And the proof was not to be made about whether R(a.k) is itself the shortest path from a to k or not. This is another subject. He started where we already knew that R(a.k) is the optimal path from a to k.
@saurabhshrivastava224
@saurabhshrivastava224 8 жыл бұрын
Great video.Thanks a lot.
@AP1977plus2
@AP1977plus2 8 жыл бұрын
Great explanation Thanks
@followoriginals2124
@followoriginals2124 6 жыл бұрын
Ameenah Palmer... Are u computer engg..
@irtizamahmud6239
@irtizamahmud6239 8 жыл бұрын
really awesome tutorial.
@luis2arm
@luis2arm 8 жыл бұрын
amazing videos! thanks!
@abedalmotytaweel2068
@abedalmotytaweel2068 6 жыл бұрын
Thank you very much for this Video.
@natiecon137
@natiecon137 9 жыл бұрын
how about J to H, H to E, E to C and C to A? I think it is also 11.
@CSBreakdown
@CSBreakdown 9 жыл бұрын
Nati Econ You're right! I missed that!
@Mjarlund
@Mjarlund 7 жыл бұрын
Please do add a note to the video, very confusing when trying to analyze what is going on.
@loam
@loam 4 жыл бұрын
Dude doesn't look like Karim Hamasni
@saitaro
@saitaro 7 жыл бұрын
To me it looks like backwards Dijkstra
@umarmurtaza2499
@umarmurtaza2499 5 жыл бұрын
exactly it is
@nSackStyles
@nSackStyles 3 жыл бұрын
Yeah but what's weird is Dijkstra is taught under Greedy Algorithm. So how is the example stated in video a part of Dynamic Programming?
@rohanbose4882
@rohanbose4882 7 жыл бұрын
Such an amazing explanation !!! *CLAPS*
@PowKu10
@PowKu10 7 жыл бұрын
Great video, thx!
@kaunghtethein3322
@kaunghtethein3322 6 жыл бұрын
thanks. u r great
@navam23
@navam23 5 жыл бұрын
Please explain how these similar solutions are derived and please note there is one solution with 11 which was missed. See Arturo's comment!
@udityanarayancom
@udityanarayancom 5 жыл бұрын
Thanks you sir
@tanchienhao
@tanchienhao 7 жыл бұрын
hi may i know whats the complexity? (im not sure is it O(NE) where N is number of nodes and E is number of edges) if so that means dijkstra is still better?
@victoriac7257
@victoriac7257 4 жыл бұрын
Wait... I thought at 2:38 that algorithm is Dijkstra's algorithm which is a greedy algorithm? Is it not? I am new to the field so I might be wrong, just wanna check...
@BharatKulRatan
@BharatKulRatan 4 жыл бұрын
proof by contradiction is little hard to understand. We first make some assumption, then make more assumptions and then we know that our first assumption was correct.
@albertosivero9040
@albertosivero9040 4 жыл бұрын
sorry, i have tried with the same approach even in forward and the paths found are the same (even ACEHJ is optimal), can you explain me why forward and backward are the same for this case? thank you
@holymountainzion7413
@holymountainzion7413 2 жыл бұрын
Principally, both forward & backward recursion result are the same but backward recursion is more reliable.
@willguo2137
@willguo2137 8 жыл бұрын
I dont get it. whats the point of going from J to A, we traversed all the nodes, isnt it same as going from A to J? as long as we traverse all the nodes, we will have an optimal solution.
@yaswantgul454
@yaswantgul454 6 жыл бұрын
A to D then, D to F then, F to I then, I to J =11
@datsnek
@datsnek 8 жыл бұрын
What is preferred way of implementing dynamic programming? I know there's a way to do it recursively and a way to do it inside a for loop and I don't know which I should concentrate on in a dp problem.
@XDTuber
@XDTuber 5 жыл бұрын
Know both
@janlight8424
@janlight8424 2 жыл бұрын
You can implement both by recursion or iteration. This is not part of DP. Recursive solution will be more elegant, but usually computationally more heavy in terms of memory ... Gain from GP lies in throwing out non-optimal solutions at every transition from/to previous/next layer of nodes. You don't need to evaluate every possible path through the graf, you discard them at some layer as definitively non-optimal.
@mohamedgomaa919
@mohamedgomaa919 8 жыл бұрын
good
@greenageguy
@greenageguy 8 жыл бұрын
First I thought this is another solution to shortest path problem, other than djikstra's, but no
@nicolebilaw8128
@nicolebilaw8128 8 жыл бұрын
Thanks!
@Leon-pn6rb
@Leon-pn6rb 8 жыл бұрын
What is the point of proof? it is so useless? Or I dont understand its importance of it
@TheSarthakverma
@TheSarthakverma 7 жыл бұрын
Does he have cold??
@km2052
@km2052 8 жыл бұрын
thx
@janlight8424
@janlight8424 2 жыл бұрын
Dynamic Programming has nothing with Fibonacci, Fibonacci is simple recursive definition, can be calculated recursively or iteratively, no chance/possibility to throw out non-optimal solutions and take advantage from DP.
@v01diejesuzz
@v01diejesuzz 8 жыл бұрын
Isn't Djikstra's Algorithm optimal than the DP approach in the first part of the video ?
@kimnguyen1227
@kimnguyen1227 7 жыл бұрын
Jagreet Das Gupta isnt the example basically Djikstra's?
@oluwaseunadeoyeoyebamiji3592
@oluwaseunadeoyeoyebamiji3592 3 жыл бұрын
4:41: There is a shorter pathway. A-D2-F1-H-J cost only 10
@MagicianCamille
@MagicianCamille 7 жыл бұрын
That proof was nonsense.
@kimnguyen1227
@kimnguyen1227 7 жыл бұрын
MagicianCamille saw this video the first time then came to same conclusion. read the book multiple times and thought it was nonsense and pointless too. now returning to this video and it is making sense. i think it would help to brush up on proof by contradiction.
@gedundakpa
@gedundakpa 7 жыл бұрын
is this proof stupid? or am i ?
Problems Without Optimal Substructure - Dynamic Programming
4:37
Mastering Dynamic Programming - How to solve any interview problem (Part 1)
19:41
Мама у нас строгая
00:20
VAVAN
Рет қаралды 4 МЛН
HELP!!!
00:46
Natan por Aí
Рет қаралды 66 МЛН
Haunted House 😰😨 LeoNata family #shorts
00:37
LeoNata Family
Рет қаралды 14 МЛН
5 Simple Steps for Solving Dynamic Programming Problems
21:27
Reducible
Рет қаралды 1,1 МЛН
N-Queens Problem - Backtracking
15:12
CSBreakdown
Рет қаралды 49 М.
Matrix Chain Multiplication - Dynamic Programming
31:01
CSBreakdown
Рет қаралды 229 М.
4 Principle  of Optimality  - Dynamic Programming introduction
14:52
Abdul Bari
Рет қаралды 1,2 МЛН
Bellman's Principal of Optimality - An Example
18:28
MolloyMaths
Рет қаралды 1,2 М.
Introduction to Trajectory Optimization
46:40
Matthew Kelly
Рет қаралды 91 М.
Dynamic Programming (Think Like a Programmer)
14:39
V. Anton Spraul
Рет қаралды 67 М.
Object-Oriented Programming is Bad
44:35
Brian Will
Рет қаралды 2,3 МЛН
Lecture 19: Dynamic Programming I: Fibonacci, Shortest Paths
51:47
MIT OpenCourseWare
Рет қаралды 2,8 МЛН
Мама у нас строгая
00:20
VAVAN
Рет қаралды 4 МЛН