@@ -578,9 +578,7 @@ But don't forget to do coding problems from above while you learn!
578
578
- [ ] [ Harvard CS50 - Asymptotic Notation (video)] ( https://www.youtube.com/watch?v=iOq5kSKqeR4 )
579
579
- [ ] [ Big O Notations (general quick tutorial) (video)] ( https://www.youtube.com/watch?v=V6mKVRU1evU )
580
580
- [ ] [ Big O Notation (and Omega and Theta) - best mathematical explanation (video)] ( https://www.youtube.com/watch?v=ei-A_wy5Yxw&index=2&list=PL1BaGV1cIH4UhkL8a9bJGG356covJ76qN )
581
- - [ ] Skiena:
582
- - [ video] ( https://www.youtube.com/watch?v=gSyDMtdPNpU&index=2&list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b )
583
- - [ slides] ( https://archive.org/details/lecture2_202008 )
581
+ - [ ] [ Skiena (video)] ( https://www.youtube.com/watch?v=z1mkCe3kVUA )
584
582
- [ ] [ UC Berkeley Big O (video)] ( https://archive.org/details/ucberkeley_webcast_VIS4YDpuP98 )
585
583
- [ ] [ Amortized Analysis (video)] ( https://www.youtube.com/watch?v=B3SpQZaAZP4&index=10&list=PL1BaGV1cIH4UhkL8a9bJGG356covJ76qN )
586
584
- [ ] TopCoder (includes recurrence relations and master theorem):
@@ -918,12 +916,12 @@ Graphs can be used to represent many problems in computer science, so this secti
918
916
- [ ] [ Depth-First Search] ( https://www.youtube.com/watch?v=IBfWDYSffUU&t=32s&ab_channel=MITOpenCourseWare )
919
917
920
918
- [ ] Skiena Lectures - great intro:
921
- - [ ] [ CSE373 2012 - Lecture 11 - Graph Data Structures (video)] ( https://www.youtube.com/watch?v=OiXxhDrFruw &list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b &index=11 )
922
- - [ ] [ CSE373 2012 - Lecture 12 - Breadth-First Search (video)] ( https://www.youtube.com/watch?v=g5vF8jscteo &list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b &index=12 )
923
- - [ ] [ CSE373 2012 - Lecture 13 - Graph Algorithms (video)] ( https://www.youtube.com/watch?v=S23W6eTcqdY &list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b &index=13 )
924
- - [ ] [ CSE373 2012 - Lecture 14 - Graph Algorithms (con't) (video)] ( https://www.youtube.com/watch?v=WitPBKGV0HY&index=14& list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b )
925
- - [ ] [ CSE373 2012 - Lecture 15 - Graph Algorithms (con't 2 ) (video)] ( https://www.youtube.com/watch?v=ia1L30l7OIg&index=15& list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b )
926
- - [ ] [ CSE373 2012 - Lecture 16 - Graph Algorithms (con't 3 ) (video)] ( https://www.youtube.com/watch?v=jgDOQq6iWy8&index=16& list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b )
919
+ - [ ] [ CSE373 2020 - Lecture 11 - Graph Data Structures (video)] ( https://www.youtube.com/watch?v=Sjk0xqWWPCc &list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx &index=10 )
920
+ - [ ] [ CSE373 2020 - Lecture 12 - Graph Traversal (video)] ( https://www.youtube.com/watch?v=ZTwjXj81NVY &list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx &index=11 )
921
+ - [ ] [ CSE373 2020 - Lecture 12 - Depth First Search (video)] ( https://www.youtube.com/watch?v=KyordYB3BOs &list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx &index=12 )
922
+ - [ ] [ CSE373 2020 - Lecture 13 - Minimum Spanning Trees (video)] ( https://www.youtube.com/watch?v=oolm2VnJUKw& list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=13 )
923
+ - [ ] [ CSE373 2020 - Lecture 14 - Minimum Spanning Trees (con't) (video)] ( https://www.youtube.com/watch?v=RktgPx0MarY& list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=14 )
924
+ - [ ] [ CSE373 2020 - Lecture 15 - Graph Algorithms (con't 2 ) (video)] ( https://www.youtube.com/watch?v=MUe5DXRhyAo& list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=15 )
927
925
928
926
- [ ] Graphs (review and more):
929
927
@@ -935,7 +933,6 @@ Graphs can be used to represent many problems in computer science, so this secti
935
933
- [ ] [ Aduni: Graph Algorithms II - DFS, BFS, Kruskal's Algorithm, Union Find Data Structure - Lecture 7 (video)] ( https://www.youtube.com/watch?v=ufj5_bppBsA&list=PLFDnELG9dpVxQCxuD-9BSy2E7BWY3t5Sm&index=7 )
936
934
- [ ] [ Aduni: Graph Algorithms III: Shortest Path - Lecture 8 (video)] ( https://www.youtube.com/watch?v=DiedsPsMKXc&list=PLFDnELG9dpVxQCxuD-9BSy2E7BWY3t5Sm&index=8 )
937
935
- [ ] [ Aduni: Graph Alg. IV: Intro to geometric algorithms - Lecture 9 (video)] ( https://www.youtube.com/watch?v=XIAQRlNkJAw&list=PLFDnELG9dpVxQCxuD-9BSy2E7BWY3t5Sm&index=9 )
938
- - [ ] ~~ [ CS 61B 2014 (starting at 58:09) (video)] ( https://youtu.be/dgjX4HdMI-Q?list=PL-XXv-cvA_iAlnI-BQr9hjqADPBtujFJd&t=3489 ) ~~
939
936
- [ ] [ CS 61B 2014: Weighted graphs (video)] ( https://archive.org/details/ucberkeley_webcast_zFbq8vOZ_0k )
940
937
- [ ] [ Greedy Algorithms: Minimum Spanning Tree (video)] ( https://www.youtube.com/watch?v=tKwnms5iRBU&index=16&list=PLUl4u3cNGP6317WaSNfmCvGym2ucw3oGp )
941
938
- [ ] [ Strongly Connected Components Kosaraju's Algorithm Graph Algorithm (video)] ( https://www.youtube.com/watch?v=RpgcYiky7uw )
@@ -978,11 +975,11 @@ Graphs can be used to represent many problems in computer science, so this secti
978
975
- This subject can be pretty difficult, as each DP soluble problem must be defined as a recursion relation, and coming up with it can be tricky.
979
976
- I suggest looking at many examples of DP problems until you have a solid understanding of the pattern involved.
980
977
- [ ] Videos:
981
- - the Skiena videos can be hard to follow since he sometimes uses the whiteboard, which is too small to see
982
- - [ ] [ Skiena: CSE373 2012 - Lecture 19 - Introduction to Dynamic Programming (video)] ( https://youtu.be/Qc2ieXRgR0k? list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b&t=1718 )
983
- - [ ] [ Skiena: CSE373 2012 - Lecture 20 - Edit Distance (video)] ( https://youtu.be/IsmMhMdyeGY? list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b&t=2749 )
984
- - [ ] [ Skiena: CSE373 2012 - Lecture 21 - Dynamic Programming Examples (video)] ( https://youtu.be/o0V9eYF4UI8? list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b&t=406 )
985
- - [ ] [ Skiena: CSE373 2012 - Lecture 22 - Applications of Dynamic Programming (video)] ( https://www.youtube.com/watch?v=dRbMC1Ltl3A &list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b &index=22 )
978
+ - [ ] [ Skiena: CSE373 2020 - Lecture 19 - Introduction to Dynamic Programming (video) ] ( https://www.youtube.com/watch?v=wAA0AMfcJHQ&list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=18 )
979
+ - [ ] [ Skiena: CSE373 2020 - Lecture 20 - Edit Distance (video)] ( https://www.youtube.com/watch?v=T3A4jlHlhtA& list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=19 )
980
+ - [ ] [ Skiena: CSE373 2020 - Lecture 20 - Edit Distance (continued) ( video)] ( https://www.youtube.com/watch?v=iPnPVcZmRbE& list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=20 )
981
+ - [ ] [ Skiena: CSE373 2020 - Lecture 21 - Dynamic Programming (video)] ( https://www.youtube.com/watch?v=2xPE4Wq8coQ& list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=21 )
982
+ - [ ] [ Skiena: CSE373 2020 - Lecture 21 - Dynamic Programming and Review (video)] ( https://www.youtube.com/watch?v=2xPE4Wq8coQ &list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx &index=21 )
986
983
- [ ] [ Simonson: Dynamic Programming 0 (starts at 59:18) (video)] ( https://youtu.be/J5aJEcOr6Eo?list=PLFDnELG9dpVxQCxuD-9BSy2E7BWY3t5Sm&t=3558 )
987
984
- [ ] [ Simonson: Dynamic Programming I - Lecture 11 (video)] ( https://www.youtube.com/watch?v=0EzHjQ_SOeU&index=11&list=PLFDnELG9dpVxQCxuD-9BSy2E7BWY3t5Sm )
988
985
- [ ] [ Simonson: Dynamic programming II - Lecture 12 (video)] ( https://www.youtube.com/watch?v=v1qiRwuJU7g&list=PLFDnELG9dpVxQCxuD-9BSy2E7BWY3t5Sm&index=12 )
@@ -1045,9 +1042,10 @@ Graphs can be used to represent many problems in computer science, so this secti
1045
1042
- [ ] [ NP Completeness III (Video)] ( https://www.youtube.com/watch?v=fCX1BGT3wjE&index=17&list=PLFDnELG9dpVxQCxuD-9BSy2E7BWY3t5Sm )
1046
1043
- [ ] [ NP Completeness IV (video)] ( https://www.youtube.com/watch?v=NKLDp3Rch3M&list=PLFDnELG9dpVxQCxuD-9BSy2E7BWY3t5Sm&index=18 )
1047
1044
- [ ] Skiena:
1048
- - [ ] [ CSE373 2012 - Lecture 23 - Introduction to NP-Completeness (video)] ( https://youtu.be/KiK5TVgXbFg?list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b&t=1508 )
1049
- - [ ] [ CSE373 2012 - Lecture 24 - NP-Completeness Proofs (video)] ( https://www.youtube.com/watch?v=27Al52X3hd4&index=24&list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b )
1050
- - [ ] [ CSE373 2012 - Lecture 25 - NP-Completeness Challenge (video)] ( https://www.youtube.com/watch?v=xCPH4gwIIXM&index=25&list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b )
1045
+ - [ ] [ CSE373 2020 - Lecture 23 - NP-Completeness (video)] ( https://www.youtube.com/watch?v=ItHp5laE1VE&list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=23 )
1046
+ - [ ] [ CSE373 2020 - Lecture 24 - Satisfiability (video)] ( https://www.youtube.com/watch?v=inaFJeCzGxU&list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=24 )
1047
+ - [ ] [ CSE373 2020 - Lecture 25 - More NP-Completeness (video)] ( https://www.youtube.com/watch?v=B-bhKxjZLlc&list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=25 )
1048
+ - [ ] [ CSE373 2020 - Lecture 26 - NP-Completeness Challenge (video)] ( https://www.youtube.com/watch?v=_EzetTkG_Cc&list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=26 )
1051
1049
- [ ] [ Complexity: P, NP, NP-completeness, Reductions (video)] ( https://www.youtube.com/watch?v=eHZifpgyH_4&list=PLUl4u3cNGP6317WaSNfmCvGym2ucw3oGp&index=22 )
1052
1050
- [ ] [ Complexity: Approximation Algorithms (video)] ( https://www.youtube.com/watch?v=MEz1J9wY2iM&list=PLUl4u3cNGP6317WaSNfmCvGym2ucw3oGp&index=24 )
1053
1051
- [ ] [ Complexity: Fixed-Parameter Algorithms (video)] ( https://www.youtube.com/watch?v=4q-jmGrmxKs&index=25&list=PLUl4u3cNGP6317WaSNfmCvGym2ucw3oGp )
@@ -1883,10 +1881,8 @@ You're never really done.
1883
1881
- [ Algorithms - Sorting - Lecture 2 (video)] ( https://www.youtube.com/watch?v=odNJmw5TOEE&list=PLFDnELG9dpVxQCxuD-9BSy2E7BWY3t5Sm&index=2 )
1884
1882
- [ Algorithms - Sorting II - Lecture 3 (video)] ( https://www.youtube.com/watch?v=hj8YKFTFKEE&list=PLFDnELG9dpVxQCxuD-9BSy2E7BWY3t5Sm&index=3 )
1885
1883
- Steven Skiena lectures on sorting:
1886
- - [ lecture begins at 26:46 (video)] ( https://youtu.be/ute-pmMkyuk?list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b&t=1600 )
1887
- - [ lecture begins at 27:40 (video)] ( https://www.youtube.com/watch?v=yLvp-pB8mak&index=8&list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b )
1888
- - [ lecture begins at 35:00 (video)] ( https://www.youtube.com/watch?v=q7K9otnzlfE&index=9&list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b )
1889
- - [ lecture begins at 23:50 (video)] ( https://www.youtube.com/watch?v=TvqIGu9Iupw&list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b&index=10 )
1884
+ - [ CSE373 2020 - Mergesort/Quicksort (video)] ( https://www.youtube.com/watch?v=jUf-UQ3a0kg&list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=8 )
1885
+ - [ CSE373 2020 - Linear Sorting (video)] ( https://www.youtube.com/watch?v=0ksyQKmre84&list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=9 )
1890
1886
1891
1887
## Video Series
1892
1888
@@ -1900,8 +1896,7 @@ Sit back and enjoy.
1900
1896
1901
1897
- [ Excellent - MIT Calculus Revisited: Single Variable Calculus] ( https://www.youtube.com/playlist?list=PL3B08AE665AB9002A )
1902
1898
1903
- - CSE373 - Analysis of Algorithms (25 videos)
1904
- - [ Skiena lectures from Algorithm Design Manual] ( https://www.youtube.com/watch?v=ZFjhkohHdAA&list=PLOtl7M3yp-DV69F32zdK7YJcNXpTunF2b&index=1 )
1899
+ - [ Skiena lectures from Algorithm Design Manual - CSE373 2020 - Analysis of Algorithms (26 videos)] ( https://www.youtube.com/watch?v=22hwcnXIGgk&list=PLOtl7M3yp-DX6ic0HGT0PUX_wiNmkWkXx&index=1 )
1905
1900
1906
1901
- [ UC Berkeley 61B (Spring 2014): Data Structures (25 videos)] ( https://archive.org/details/ucberkeley-webcast-PL-XXv-cvA_iAlnI-BQr9hjqADPBtujFJd )
1907
1902
0 commit comments