{"message": {"transcript": [{"chunks": [{"end": 0.16, "start": 0.0, "text": "The"}, {"end": 0.52, "start": 0.16, "text": "following"}, {"end": 1.16, "start": 0.52, "text": "content"}, {"end": 1.28, "start": 1.16, "text": "is"}, {"end": 1.76, "start": 1.28, "text": "provided"}, {"end": 2.0, "start": 1.76, "text": "under"}, {"end": 2.0, "start": 2.0, "text": "a"}, {"end": 2.44, "start": 2.0, "text": "Creative"}, {"end": 2.88, "start": 2.44, "text": "Commons"}, {"end": 3.92, "start": 2.88, "text": "license."}, {"end": 4.12, "start": 3.92, "text": "Your"}, {"end": 4.68, "start": 4.12, "text": "support"}, {"end": 5.0, "start": 4.68, "text": "will"}, {"end": 5.16, "start": 5.0, "text": "help"}, {"end": 5.64, "start": 5.16, "text": "MIT"}, {"end": 6.28, "start": 5.64, "text": "OpenCourseWare"}, {"end": 6.44, "start": 6.28, "text": "continue"}, {"end": 6.96, "start": 6.44, "text": "to"}, {"end": 7.4, "start": 6.96, "text": "offer"}, {"end": 7.56, "start": 7.4, "text": "high"}, {"end": 8.12, "start": 7.56, "text": "quality"}, {"end": 8.68, "start": 8.12, "text": "educational"}, {"end": 9.36, "start": 8.68, "text": "resources"}, {"end": 9.48, "start": 9.36, "text": "for"}, {"end": 9.76, "start": 9.48, "text": "free."}, {"end": 10.68, "start": 9.76, "text": "To"}, {"end": 10.88, "start": 10.68, "text": "make"}, {"end": 10.92, "start": 10.88, "text": "a"}, {"end": 11.72, "start": 10.92, "text": "donation"}, {"end": 11.88, "start": 11.72, "text": "or"}, {"end": 12.36, "start": 11.88, "text": "view"}, {"end": 12.84, "start": 12.36, "text": "additional"}, {"end": 13.28, "start": 12.84, "text": "materials"}, {"end": 13.48, "start": 13.28, "text": "from"}, {"end": 13.92, "start": 13.48, "text": "hundreds"}, {"end": 13.96, "start": 13.92, "text": "of"}, {"end": 14.4, "start": 13.96, "text": "MIT"}, {"end": 15.4, "start": 14.4, "text": "courses,"}, {"end": 15.76, "start": 15.4, "text": "visit"}, {"end": 16.28, "start": 15.76, "text": "MIT"}, {"end": 16.84, "start": 16.28, "text": "OpenCourseWare"}, {"end": 17.24, "start": 16.84, "text": "at"}, {"end": 18.2, "start": 17.24, "text": "ocw.mit.edu."}, {"end": 18.56, "start": 18.2, "text": "Hi,"}, {"end": 18.72, "start": 18.56, "text": "I'm"}, {"end": 19.28, "start": 18.72, "text": "Srini"}, {"end": 22.72, "start": 19.28, "text": "Davidas."}, {"end": 23.4, "start": 22.72, "text": "I'm"}, {"end": 23.84, "start": 23.4, "text": "a"}, {"end": 25.0, "start": 23.84, "text": "professor"}, {"end": 25.08, "start": 25.0, "text": "of"}, {"end": 25.76, "start": 25.08, "text": "lecture"}, {"end": 26.2, "start": 25.76, "text": "engineering"}, {"end": 26.24, "start": 26.2, "text": "and"}, {"end": 26.96, "start": 26.24, "text": "computer"}, {"end": 27.64, "start": 26.96, "text": "science."}, {"end": 27.8, "start": 27.64, "text": "I'm"}, {"end": 28.0, "start": 27.8, "text": "going"}, {"end": 28.0, "start": 28.0, "text": "to"}, {"end": 28.04, "start": 28.0, "text": "be"}, {"end": 28.84, "start": 28.04, "text": "co-lecturing"}, {"end": 29.96, "start": 28.84, "text": "6.006."}], "text": " The following content is provided under a Creative Commons license. Your support will help MIT OpenCourseWare continue to offer high quality educational resources for free. To make a donation or view additional materials from hundreds of MIT courses, visit MIT OpenCourseWare at ocw.mit.edu. Hi, I'm Srini Davidas. I'm a professor of lecture engineering and computer science. I'm going to be co-lecturing 6.006."}, {"chunks": [{"end": 30.88, "start": 30.0, "text": "Introduction"}, {"end": 31.0, "start": 30.88, "text": "to"}, {"end": 31.68, "start": 31.0, "text": "Algorithms"}, {"end": 31.72, "start": 31.68, "text": "this"}, {"end": 32.44, "start": 31.72, "text": "term"}, {"end": 32.68, "start": 32.44, "text": "with"}, {"end": 33.36, "start": 32.68, "text": "Professor"}, {"end": 33.6, "start": 33.36, "text": "Eric"}, {"end": 34.0, "start": 33.6, "text": "DeMaine."}, {"end": 34.12, "start": 34.0, "text": "Eric,"}, {"end": 34.84, "start": 34.12, "text": "say"}, {"end": 35.12, "start": 34.84, "text": "hi."}, {"end": 35.88, "start": 35.12, "text": "Hi,"}, {"end": 36.36, "start": 35.88, "text": "Eric."}, {"end": 36.92, "start": 36.36, "text": "And"}, {"end": 37.16, "start": 36.92, "text": "we"}, {"end": 37.4, "start": 37.16, "text": "hope"}, {"end": 38.68, "start": 37.4, "text": "you're"}, {"end": 39.08, "start": 38.68, "text": "going"}, {"end": 39.44, "start": 39.08, "text": "to"}, {"end": 40.08, "start": 39.44, "text": "have"}, {"end": 40.4, "start": 40.08, "text": "a"}, {"end": 40.6, "start": 40.4, "text": "fun"}, {"end": 40.92, "start": 40.6, "text": "time"}, {"end": 40.96, "start": 40.92, "text": "in"}, {"end": 42.6, "start": 40.96, "text": "6.006"}, {"end": 43.6, "start": 42.6, "text": "learning"}, {"end": 44.12, "start": 43.6, "text": "a"}, {"end": 45.44, "start": 44.12, "text": "variety"}, {"end": 45.8, "start": 45.44, "text": "of"}, {"end": 47.08, "start": 45.8, "text": "algorithms."}, {"end": 47.480000000000004, "start": 47.08, "text": "What"}, {"end": 47.760000000000005, "start": 47.480000000000004, "text": "I"}, {"end": 47.8, "start": 47.760000000000005, "text": "want"}, {"end": 47.84, "start": 47.8, "text": "to"}, {"end": 48.480000000000004, "start": 47.84, "text": "do"}, {"end": 48.6, "start": 48.480000000000004, "text": "today"}, {"end": 48.68, "start": 48.6, "text": "is"}, {"end": 48.8, "start": 48.68, "text": "spend"}, {"end": 49.8, "start": 48.8, "text": "literally"}, {"end": 50.0, "start": 49.8, "text": "a"}, {"end": 50.480000000000004, "start": 50.0, "text": "minute"}, {"end": 50.92, "start": 50.480000000000004, "text": "or"}, {"end": 50.96, "start": 50.92, "text": "so"}, {"end": 51.44, "start": 50.96, "text": "on"}, {"end": 52.32, "start": 51.44, "text": "administrative"}, {"end": 53.4, "start": 52.32, "text": "details,"}, {"end": 53.760000000000005, "start": 53.4, "text": "maybe"}, {"end": 53.96, "start": 53.760000000000005, "text": "even"}, {"end": 54.68, "start": 53.96, "text": "less."}, {"end": 55.04, "start": 54.68, "text": "What"}, {"end": 55.519999999999996, "start": 55.04, "text": "I'd"}, {"end": 55.84, "start": 55.519999999999996, "text": "like"}, {"end": 55.84, "start": 55.84, "text": "to"}, {"end": 55.84, "start": 55.84, "text": "do"}, {"end": 55.84, "start": 55.84, "text": "is"}, {"end": 55.84, "start": 55.84, "text": "to"}, {"end": 55.84, "start": 55.84, "text": "tell"}, {"end": 55.84, "start": 55.84, "text": "you"}, {"end": 55.84, "start": 55.84, "text": "to"}, {"end": 56.36, "start": 55.84, "text": "go"}, {"end": 56.480000000000004, "start": 56.36, "text": "to"}, {"end": 56.8, "start": 56.480000000000004, "text": "the"}, {"end": 57.36, "start": 56.8, "text": "website"}, {"end": 57.6, "start": 57.36, "text": "that's"}, {"end": 57.96, "start": 57.6, "text": "listed"}, {"end": 58.04, "start": 57.96, "text": "up"}, {"end": 58.879999999999995, "start": 58.04, "text": "there"}, {"end": 59.120000000000005, "start": 58.879999999999995, "text": "and"}, {"end": 59.480000000000004, "start": 59.120000000000005, "text": "read"}, {"end": 59.96, "start": 59.480000000000004, "text": "it."}], "text": " Introduction to Algorithms this term with Professor Eric DeMaine. Eric, say hi. Hi, Eric. And we hope you're going to have a fun time in 6.006 learning a variety of algorithms. What I want to do today is spend literally a minute or so on administrative details, maybe even less. What I'd like to do is to tell you to go to the website that's listed up there and read it."}, {"chunks": [{"end": 60.68, "start": 60.0, "text": "And"}, {"end": 60.84, "start": 60.68, "text": "you'll"}, {"end": 61.0, "start": 60.84, "text": "get"}, {"end": 61.52, "start": 61.0, "text": "all"}, {"end": 61.52, "start": 61.52, "text": "the"}, {"end": 62.32, "start": 61.52, "text": "information"}, {"end": 62.56, "start": 62.32, "text": "you"}, {"end": 63.28, "start": 62.56, "text": "need"}, {"end": 63.72, "start": 63.28, "text": "about"}, {"end": 64.24, "start": 63.72, "text": "what"}, {"end": 64.68, "start": 64.24, "text": "this"}, {"end": 65.08, "start": 64.68, "text": "class"}, {"end": 65.12, "start": 65.08, "text": "is"}, {"end": 65.48, "start": 65.12, "text": "about"}, {"end": 65.68, "start": 65.48, "text": "from"}, {"end": 65.8, "start": 65.68, "text": "a"}, {"end": 66.2, "start": 65.8, "text": "standpoint"}, {"end": 66.48, "start": 66.2, "text": "of"}, {"end": 67.36, "start": 66.48, "text": "syllabus,"}, {"end": 67.88, "start": 67.36, "text": "what's"}, {"end": 68.52, "start": 67.88, "text": "expected"}, {"end": 68.88, "start": 68.52, "text": "of"}, {"end": 70.32, "start": 68.88, "text": "you,"}, {"end": 70.96000000000001, "start": 70.32, "text": "the"}, {"end": 71.28, "start": 70.96000000000001, "text": "problem"}, {"end": 71.52, "start": 71.28, "text": "set"}, {"end": 72.44, "start": 71.52, "text": "schedule,"}, {"end": 72.6, "start": 72.44, "text": "the"}, {"end": 72.92, "start": 72.6, "text": "quiz"}, {"end": 73.88, "start": 72.92, "text": "schedule,"}, {"end": 74.36, "start": 73.88, "text": "and"}, {"end": 74.64, "start": 74.36, "text": "so"}, {"end": 75.64, "start": 74.64, "text": "on"}, {"end": 77.03999999999999, "start": 75.64, "text": "and"}, {"end": 77.76, "start": 77.03999999999999, "text": "so"}, {"end": 78.56, "start": 77.76, "text": "forth."}, {"end": 78.72, "start": 78.56, "text": "I"}, {"end": 79.03999999999999, "start": 78.72, "text": "want"}, {"end": 79.03999999999999, "start": 79.03999999999999, "text": "to"}, {"end": 79.44, "start": 79.03999999999999, "text": "dive"}, {"end": 79.84, "start": 79.44, "text": "right"}, {"end": 79.96000000000001, "start": 79.84, "text": "in"}, {"end": 80.16, "start": 79.96000000000001, "text": "and"}, {"end": 80.84, "start": 80.16, "text": "tell"}, {"end": 81.16, "start": 80.84, "text": "you"}, {"end": 81.64, "start": 81.16, "text": "about"}, {"end": 81.8, "start": 81.64, "text": "interesting"}, {"end": 81.84, "start": 81.8, "text": "things"}, {"end": 81.96000000000001, "start": 81.84, "text": "like"}, {"end": 82.4, "start": 81.96000000000001, "text": "algorithms"}, {"end": 82.44, "start": 82.4, "text": "and"}, {"end": 83.16, "start": 82.44, "text": "complexity"}, {"end": 83.44, "start": 83.16, "text": "of"}, {"end": 84.52, "start": 83.44, "text": "algorithms."}, {"end": 84.68, "start": 84.52, "text": "I"}, {"end": 85.03999999999999, "start": 84.68, "text": "want"}, {"end": 85.28, "start": 85.03999999999999, "text": "to"}, {"end": 85.72, "start": 85.28, "text": "spend"}, {"end": 85.72, "start": 85.72, "text": "some"}, {"end": 85.96000000000001, "start": 85.72, "text": "time"}, {"end": 86.0, "start": 85.96000000000001, "text": "giving"}, {"end": 86.0, "start": 86.0, "text": "you"}, {"end": 86.12, "start": 86.0, "text": "an"}, {"end": 87.0, "start": 86.12, "text": "overview"}, {"end": 87.12, "start": 87.0, "text": "of"}, {"end": 87.36, "start": 87.12, "text": "the"}, {"end": 87.84, "start": 87.36, "text": "course"}, {"end": 89.36, "start": 87.84, "text": "content"}, {"end": 89.68, "start": 89.36, "text": "and"}, {"end": 89.96000000000001, "start": 89.68, "text": "then"}], "text": " And you'll get all the information you need about what this class is about from a standpoint of syllabus, what's expected of you, the problem set schedule, the quiz schedule, and so on and so forth. I want to dive right in and tell you about interesting things like algorithms and complexity of algorithms. I want to spend some time giving you an overview of the course content and then"}, {"chunks": [{"end": 90.16, "start": 90.0, "text": "We're"}, {"end": 90.44, "start": 90.16, "text": "going"}, {"end": 91.08, "start": 90.44, "text": "to"}, {"end": 91.36, "start": 91.08, "text": "dive"}, {"end": 91.84, "start": 91.36, "text": "right"}, {"end": 92.0, "start": 91.84, "text": "in"}, {"end": 92.12, "start": 92.0, "text": "and"}, {"end": 92.68, "start": 92.12, "text": "look"}, {"end": 93.12, "start": 92.68, "text": "at"}, {"end": 93.2, "start": 93.12, "text": "a"}, {"end": 93.84, "start": 93.2, "text": "particular"}, {"end": 94.6, "start": 93.84, "text": "problem"}, {"end": 94.88, "start": 94.6, "text": "of"}, {"end": 95.2, "start": 94.88, "text": "peak"}, {"end": 95.68, "start": 95.2, "text": "finding,"}, {"end": 96.24, "start": 95.68, "text": "both"}, {"end": 96.48, "start": 96.24, "text": "a"}, {"end": 97.12, "start": 96.48, "text": "one-dimensional"}, {"end": 97.8, "start": 97.12, "text": "version"}, {"end": 97.96, "start": 97.8, "text": "and"}, {"end": 98.16, "start": 97.96, "text": "a"}, {"end": 98.76, "start": 98.16, "text": "two-dimensional"}, {"end": 99.6, "start": 98.76, "text": "version,"}, {"end": 99.64, "start": 99.6, "text": "and"}, {"end": 99.88, "start": 99.64, "text": "talk"}, {"end": 100.16, "start": 99.88, "text": "about"}, {"end": 101.36, "start": 100.16, "text": "algorithms"}, {"end": 101.36, "start": 101.36, "text": "to"}, {"end": 101.88, "start": 101.36, "text": "solve"}, {"end": 102.08, "start": 101.88, "text": "this"}, {"end": 102.32, "start": 102.08, "text": "peak"}, {"end": 102.64, "start": 102.32, "text": "finding"}, {"end": 104.12, "start": 102.64, "text": "problem,"}, {"end": 104.96000000000001, "start": 104.12, "text": "both"}, {"end": 105.52, "start": 104.96000000000001, "text": "varieties"}, {"end": 105.88, "start": 105.52, "text": "of"}, {"end": 106.08, "start": 105.88, "text": "it."}, {"end": 106.56, "start": 106.08, "text": "And"}, {"end": 107.0, "start": 106.56, "text": "you'll"}, {"end": 108.28, "start": 107.0, "text": "find"}, {"end": 108.56, "start": 108.28, "text": "that"}, {"end": 108.88, "start": 108.56, "text": "there's"}, {"end": 109.96000000000001, "start": 108.88, "text": "really"}, {"end": 110.08, "start": 109.96000000000001, "text": "a"}, {"end": 111.48, "start": 110.08, "text": "difference"}, {"end": 112.0, "start": 111.48, "text": "between"}, {"end": 112.24, "start": 112.0, "text": "these"}, {"end": 112.84, "start": 112.24, "text": "various"}, {"end": 113.0, "start": 112.84, "text": "algorithms"}, {"end": 113.2, "start": 113.0, "text": "that"}, {"end": 113.84, "start": 113.2, "text": "we'll"}, {"end": 113.92, "start": 113.84, "text": "look"}, {"end": 114.2, "start": 113.92, "text": "at"}, {"end": 114.24, "start": 114.2, "text": "in"}, {"end": 114.64, "start": 114.24, "text": "terms"}, {"end": 114.64, "start": 114.64, "text": "of"}, {"end": 114.84, "start": 114.64, "text": "their"}, {"end": 115.56, "start": 114.84, "text": "complexity."}, {"end": 116.4, "start": 115.56, "text": "And"}, {"end": 116.68, "start": 116.4, "text": "what"}, {"end": 116.88, "start": 116.68, "text": "I"}, {"end": 117.08, "start": 116.88, "text": "mean"}, {"end": 117.56, "start": 117.08, "text": "by"}, {"end": 117.64, "start": 117.56, "text": "that"}, {"end": 118.92, "start": 117.64, "text": "is"}, {"end": 119.16, "start": 118.92, "text": "you're"}, {"end": 119.68, "start": 119.16, "text": "going"}, {"end": 119.76, "start": 119.68, "text": "to"}, {"end": 119.96000000000001, "start": 119.76, "text": "have"}], "text": " We're going to dive right in and look at a particular problem of peak finding, both a one-dimensional version and a two-dimensional version, and talk about algorithms to solve this peak finding problem, both varieties of it. And you'll find that there's really a difference between these various algorithms that we'll look at in terms of their complexity. And what I mean by that is you're going to have"}, {"chunks": [{"end": 120.8, "start": 120.0, "text": "different"}, {"end": 121.08, "start": 120.8, "text": "run"}, {"end": 121.48, "start": 121.08, "text": "times"}, {"end": 121.48, "start": 121.48, "text": "of"}, {"end": 121.72, "start": 121.48, "text": "these"}, {"end": 122.72, "start": 121.72, "text": "algorithms,"}, {"end": 123.28, "start": 122.72, "text": "depending"}, {"end": 123.36, "start": 123.28, "text": "on"}, {"end": 123.4, "start": 123.36, "text": "input"}, {"end": 125.4, "start": 123.4, "text": "size,"}, {"end": 125.76, "start": 125.4, "text": "based"}, {"end": 126.0, "start": 125.76, "text": "on"}, {"end": 126.32, "start": 126.0, "text": "how"}, {"end": 126.56, "start": 126.32, "text": "efficient"}, {"end": 126.8, "start": 126.56, "text": "these"}, {"end": 128.64, "start": 126.8, "text": "algorithms"}, {"end": 129.08, "start": 128.64, "text": "are."}, {"end": 130.52, "start": 129.08, "text": "And"}, {"end": 130.6, "start": 130.52, "text": "a"}, {"end": 131.2, "start": 130.6, "text": "prerequisite"}, {"end": 131.32, "start": 131.2, "text": "for"}, {"end": 131.44, "start": 131.32, "text": "this"}, {"end": 132.08, "start": 131.44, "text": "class"}, {"end": 132.68, "start": 132.08, "text": "is"}, {"end": 134.36, "start": 132.68, "text": "6042."}, {"end": 134.88, "start": 134.36, "text": "And"}, {"end": 134.88, "start": 134.88, "text": "in"}, {"end": 135.72, "start": 134.88, "text": "6042,"}, {"end": 136.0, "start": 135.72, "text": "you"}, {"end": 136.24, "start": 136.0, "text": "learned"}, {"end": 136.56, "start": 136.24, "text": "about"}, {"end": 137.12, "start": 136.56, "text": "asymptotic"}, {"end": 138.6, "start": 137.12, "text": "complexity."}, {"end": 138.96, "start": 138.6, "text": "And"}, {"end": 139.07999999999998, "start": 138.96, "text": "you'll"}, {"end": 139.32, "start": 139.07999999999998, "text": "see"}, {"end": 140.07999999999998, "start": 139.32, "text": "that"}, {"end": 140.2, "start": 140.07999999999998, "text": "in"}, {"end": 140.4, "start": 140.2, "text": "this"}, {"end": 141.2, "start": 140.4, "text": "lecture,"}, {"end": 142.12, "start": 141.2, "text": "we'll"}, {"end": 143.4, "start": 142.12, "text": "analyze"}, {"end": 143.8, "start": 143.4, "text": "relatively"}, {"end": 144.04, "start": 143.8, "text": "simple"}, {"end": 144.72, "start": 144.04, "text": "algorithms"}, {"end": 145.44, "start": 144.72, "text": "today"}, {"end": 145.48, "start": 145.44, "text": "in"}, {"end": 145.88, "start": 145.48, "text": "terms"}, {"end": 145.96, "start": 145.88, "text": "of"}, {"end": 146.4, "start": 145.96, "text": "their"}, {"end": 146.96, "start": 146.4, "text": "asymptotic"}, {"end": 147.84, "start": 146.96, "text": "complexity."}, {"end": 148.07999999999998, "start": 147.84, "text": "And"}, {"end": 148.4, "start": 148.07999999999998, "text": "you'll"}, {"end": 148.64, "start": 148.4, "text": "be"}, {"end": 148.84, "start": 148.64, "text": "able"}, {"end": 148.84, "start": 148.84, "text": "to"}, {"end": 149.96, "start": 148.84, "text": "compare"}], "text": " different run times of these algorithms, depending on input size, based on how efficient these algorithms are. And a prerequisite for this class is 6042. And in 6042, you learned about asymptotic complexity. And you'll see that in this lecture, we'll analyze relatively simple algorithms today in terms of their asymptotic complexity. And you'll be able to compare"}, {"chunks": [{"end": 150.08, "start": 150.0, "text": "and"}, {"end": 150.44, "start": 150.08, "text": "say"}, {"end": 150.44, "start": 150.44, "text": "that"}, {"end": 150.52, "start": 150.44, "text": "this"}, {"end": 150.96, "start": 150.52, "text": "algorithm"}, {"end": 151.2, "start": 150.96, "text": "is"}, {"end": 151.8, "start": 151.2, "text": "faster"}, {"end": 153.4, "start": 151.8, "text": "than"}, {"end": 153.76, "start": 153.4, "text": "this"}, {"end": 154.08, "start": 153.76, "text": "other"}, {"end": 154.48, "start": 154.08, "text": "one,"}, {"end": 154.76, "start": 154.48, "text": "assuming"}, {"end": 154.76, "start": 154.76, "text": "that"}, {"end": 154.76, "start": 154.76, "text": "you"}, {"end": 154.84, "start": 154.76, "text": "have"}, {"end": 154.96, "start": 154.84, "text": "large"}, {"end": 155.52, "start": 154.96, "text": "inputs"}, {"end": 156.12, "start": 155.52, "text": "because"}, {"end": 156.92, "start": 156.12, "text": "it's"}, {"end": 158.16, "start": 156.92, "text": "asymptotically"}, {"end": 158.44, "start": 158.16, "text": "less"}, {"end": 160.8, "start": 158.44, "text": "complex."}, {"end": 160.92, "start": 160.8, "text": "So"}, {"end": 161.48, "start": 160.92, "text": "let's"}, {"end": 162.44, "start": 161.48, "text": "dive"}, {"end": 164.68, "start": 162.44, "text": "right"}, {"end": 165.6, "start": 164.68, "text": "in"}, {"end": 165.84, "start": 165.6, "text": "and"}, {"end": 167.36, "start": 165.84, "text": "talk"}, {"end": 167.6, "start": 167.36, "text": "about"}, {"end": 167.84, "start": 167.6, "text": "the"}, {"end": 168.88, "start": 167.84, "text": "class."}, {"end": 169.76, "start": 168.88, "text": "So"}, {"end": 170.0, "start": 169.76, "text": "the"}, {"end": 172.4, "start": 170.0, "text": "one"}, {"end": 173.2, "start": 172.4, "text": "sentence"}, {"end": 173.72, "start": 173.2, "text": "summary"}, {"end": 173.72, "start": 173.72, "text": "of"}, {"end": 173.88, "start": 173.72, "text": "this"}, {"end": 174.52, "start": 173.88, "text": "class"}, {"end": 174.72, "start": 174.52, "text": "is"}, {"end": 175.12, "start": 174.72, "text": "that"}, {"end": 176.07999999999998, "start": 175.12, "text": "this"}, {"end": 176.52, "start": 176.07999999999998, "text": "is"}, {"end": 177.24, "start": 176.52, "text": "about"}, {"end": 177.68, "start": 177.24, "text": "efficient"}, {"end": 178.44, "start": 177.68, "text": "procedures"}, {"end": 179.52, "start": 178.44, "text": "for"}, {"end": 179.96, "start": 179.52, "text": "solving"}], "text": " and say that this algorithm is faster than this other one, assuming that you have large inputs because it's asymptotically less complex. So let's dive right in and talk about the class. So the one sentence summary of this class is that this is about efficient procedures for solving"}, {"chunks": [{"end": 181.52, "start": 180.0, "text": "Problems"}, {"end": 181.84, "start": 181.52, "text": "on"}, {"end": 182.6, "start": 181.84, "text": "large"}, {"end": 183.8, "start": 182.6, "text": "inputs."}, {"end": 183.88, "start": 183.8, "text": "And"}, {"end": 184.84, "start": 183.88, "text": "when"}, {"end": 185.12, "start": 184.84, "text": "I"}, {"end": 185.8, "start": 185.12, "text": "say"}, {"end": 185.88, "start": 185.8, "text": "large"}, {"end": 186.12, "start": 185.88, "text": "inputs,"}, {"end": 186.4, "start": 186.12, "text": "I"}, {"end": 186.4, "start": 186.4, "text": "mean"}, {"end": 186.76, "start": 186.4, "text": "things"}, {"end": 187.96, "start": 186.76, "text": "like"}, {"end": 188.6, "start": 187.96, "text": "the"}, {"end": 188.96, "start": 188.6, "text": "US"}, {"end": 189.48, "start": 188.96, "text": "highway"}, {"end": 190.24, "start": 189.48, "text": "system,"}, {"end": 190.36, "start": 190.24, "text": "a"}, {"end": 190.88, "start": 190.36, "text": "map"}, {"end": 190.96, "start": 190.88, "text": "of"}, {"end": 191.24, "start": 190.96, "text": "all"}, {"end": 191.56, "start": 191.24, "text": "of"}, {"end": 191.88, "start": 191.56, "text": "the"}, {"end": 192.32, "start": 191.88, "text": "highways"}, {"end": 192.32, "start": 192.32, "text": "in"}, {"end": 192.4, "start": 192.32, "text": "the"}, {"end": 192.8, "start": 192.4, "text": "United"}, {"end": 194.12, "start": 192.8, "text": "States,"}, {"end": 194.4, "start": 194.12, "text": "the"}, {"end": 194.72, "start": 194.4, "text": "human"}, {"end": 195.96, "start": 194.72, "text": "genome,"}, {"end": 196.07999999999998, "start": 195.96, "text": "which"}, {"end": 196.68, "start": 196.07999999999998, "text": "has"}, {"end": 196.88, "start": 196.68, "text": "a"}, {"end": 197.24, "start": 196.88, "text": "billion"}, {"end": 197.76, "start": 197.24, "text": "letters"}, {"end": 197.8, "start": 197.76, "text": "in"}, {"end": 198.16, "start": 197.8, "text": "its"}, {"end": 199.76, "start": 198.16, "text": "alphabet,"}, {"end": 200.8, "start": 199.76, "text": "a"}, {"end": 201.24, "start": 200.8, "text": "social"}, {"end": 201.68, "start": 201.24, "text": "network"}, {"end": 202.2, "start": 201.68, "text": "corresponding"}, {"end": 202.32, "start": 202.2, "text": "to"}, {"end": 202.64, "start": 202.32, "text": "Facebook"}, {"end": 203.32, "start": 202.64, "text": "that,"}, {"end": 203.68, "start": 203.32, "text": "I"}, {"end": 204.0, "start": 203.68, "text": "guess,"}, {"end": 204.44, "start": 204.0, "text": "has"}, {"end": 205.07999999999998, "start": 204.44, "text": "500"}, {"end": 205.28, "start": 205.07999999999998, "text": "million"}, {"end": 205.72, "start": 205.28, "text": "nodes"}, {"end": 205.8, "start": 205.72, "text": "or"}, {"end": 206.8, "start": 205.8, "text": "so."}, {"end": 207.07999999999998, "start": 206.8, "text": "So"}, {"end": 207.44, "start": 207.07999999999998, "text": "these"}, {"end": 207.88, "start": 207.44, "text": "are"}, {"end": 208.0, "start": 207.88, "text": "large"}, {"end": 208.2, "start": 208.0, "text": "inputs."}, {"end": 208.48, "start": 208.2, "text": "Now,"}, {"end": 208.64, "start": 208.48, "text": "our"}, {"end": 208.92000000000002, "start": 208.64, "text": "definition"}, {"end": 209.04, "start": 208.92000000000002, "text": "of"}, {"end": 209.64, "start": 209.04, "text": "large"}, {"end": 209.8, "start": 209.64, "text": "is"}, {"end": 209.96, "start": 209.8, "text": "really"}], "text": " Problems on large inputs. And when I say large inputs, I mean things like the US highway system, a map of all of the highways in the United States, the human genome, which has a billion letters in its alphabet, a social network corresponding to Facebook that, I guess, has 500 million nodes or so. So these are large inputs. Now, our definition of large is really"}, {"chunks": [{"end": 210.52, "start": 210.0, "text": "changed"}, {"end": 210.52, "start": 210.52, "text": "with"}, {"end": 210.64, "start": 210.52, "text": "the"}, {"end": 211.44, "start": 210.64, "text": "times."}, {"end": 211.64, "start": 211.44, "text": "And"}, {"end": 211.84, "start": 211.64, "text": "so"}, {"end": 212.08, "start": 211.84, "text": "really,"}, {"end": 212.12, "start": 212.08, "text": "the"}, {"end": 212.64, "start": 212.12, "text": "21st"}, {"end": 213.16, "start": 212.64, "text": "century"}, {"end": 214.32, "start": 213.16, "text": "definition"}, {"end": 214.72, "start": 214.32, "text": "of"}, {"end": 215.4, "start": 214.72, "text": "large"}, {"end": 215.84, "start": 215.4, "text": "is,"}, {"end": 215.92, "start": 215.84, "text": "I"}, {"end": 216.2, "start": 215.92, "text": "guess,"}, {"end": 216.36, "start": 216.2, "text": "a"}, {"end": 217.08, "start": 216.36, "text": "trillion."}, {"end": 217.44, "start": 217.08, "text": "Back"}, {"end": 217.52, "start": 217.44, "text": "when"}, {"end": 217.68, "start": 217.52, "text": "I"}, {"end": 217.96, "start": 217.68, "text": "was"}, {"end": 218.36, "start": 217.96, "text": "your"}, {"end": 219.12, "start": 218.36, "text": "age,"}, {"end": 219.52, "start": 219.12, "text": "large"}, {"end": 219.76, "start": 219.52, "text": "was"}, {"end": 220.04, "start": 219.76, "text": "like"}, {"end": 221.0, "start": 220.04, "text": "1,000."}, {"end": 221.2, "start": 221.0, "text": "I"}, {"end": 221.92, "start": 221.2, "text": "guess"}, {"end": 222.4, "start": 221.92, "text": "I'm"}, {"end": 223.04, "start": 222.4, "text": "dating"}, {"end": 223.52, "start": 223.04, "text": "myself"}, {"end": 224.12, "start": 223.52, "text": "here."}, {"end": 224.8, "start": 224.12, "text": "Back"}, {"end": 225.56, "start": 224.8, "text": "when"}, {"end": 226.12, "start": 225.56, "text": "Eric"}, {"end": 226.28, "start": 226.12, "text": "was"}, {"end": 226.96, "start": 226.28, "text": "your"}, {"end": 227.24, "start": 226.96, "text": "age,"}, {"end": 227.6, "start": 227.24, "text": "it"}, {"end": 228.2, "start": 227.6, "text": "was"}, {"end": 228.68, "start": 228.2, "text": "a"}, {"end": 229.12, "start": 228.68, "text": "million."}, {"end": 230.16, "start": 229.12, "text": "But"}, {"end": 230.68, "start": 230.16, "text": "what's"}, {"end": 231.76, "start": 230.68, "text": "happening,"}, {"end": 232.88, "start": 231.76, "text": "really,"}, {"end": 233.07999999999998, "start": 232.88, "text": "the"}, {"end": 234.04, "start": 233.07999999999998, "text": "world"}, {"end": 234.07999999999998, "start": 234.04, "text": "is"}, {"end": 234.44, "start": 234.07999999999998, "text": "moving"}, {"end": 234.96, "start": 234.44, "text": "faster."}, {"end": 235.24, "start": 234.96, "text": "Things"}, {"end": 235.44, "start": 235.24, "text": "are"}, {"end": 235.6, "start": 235.44, "text": "getting"}, {"end": 235.84, "start": 235.6, "text": "bigger."}, {"end": 236.24, "start": 235.84, "text": "We"}, {"end": 236.28, "start": 236.24, "text": "have"}, {"end": 236.8, "start": 236.28, "text": "the"}, {"end": 237.92000000000002, "start": 236.8, "text": "capability"}, {"end": 238.0, "start": 237.92000000000002, "text": "of"}, {"end": 238.92000000000002, "start": 238.0, "text": "computing"}, {"end": 239.2, "start": 238.92000000000002, "text": "on"}, {"end": 239.84, "start": 239.2, "text": "large"}, {"end": 239.96, "start": 239.84, "text": "inputs."}], "text": " changed with the times. And so really, the 21st century definition of large is, I guess, a trillion. Back when I was your age, large was like 1,000. I guess I'm dating myself here. Back when Eric was your age, it was a million. But what's happening, really, the world is moving faster. Things are getting bigger. We have the capability of computing on large inputs."}, {"chunks": [{"end": 240.88, "start": 240.0, "text": "But"}, {"end": 241.52, "start": 240.88, "text": "that"}, {"end": 241.88, "start": 241.52, "text": "doesn't"}, {"end": 242.32, "start": 241.88, "text": "mean"}, {"end": 242.48, "start": 242.32, "text": "that"}, {"end": 243.2, "start": 242.48, "text": "efficiency"}, {"end": 243.56, "start": 243.2, "text": "isn't"}, {"end": 243.8, "start": 243.56, "text": "of"}, {"end": 244.28, "start": 243.8, "text": "paramount"}, {"end": 244.76, "start": 244.28, "text": "concern."}, {"end": 245.2, "start": 244.76, "text": "The"}, {"end": 245.4, "start": 245.2, "text": "fact"}, {"end": 245.6, "start": 245.4, "text": "of"}, {"end": 245.88, "start": 245.6, "text": "the"}, {"end": 246.52, "start": 245.88, "text": "matter"}, {"end": 246.72, "start": 246.52, "text": "is"}, {"end": 246.92, "start": 246.72, "text": "that"}, {"end": 246.96, "start": 246.92, "text": "you"}, {"end": 247.8, "start": 246.96, "text": "can"}, {"end": 247.96, "start": 247.8, "text": "maybe"}, {"end": 248.44, "start": 247.96, "text": "scan"}, {"end": 248.52, "start": 248.44, "text": "a"}, {"end": 248.56, "start": 248.52, "text": "billion"}, {"end": 248.8, "start": 248.56, "text": "elements"}, {"end": 249.04, "start": 248.8, "text": "in"}, {"end": 250.24, "start": 249.04, "text": "a"}, {"end": 250.48, "start": 250.24, "text": "matter"}, {"end": 250.72, "start": 250.48, "text": "of"}, {"end": 251.84, "start": 250.72, "text": "seconds."}, {"end": 252.68, "start": 251.84, "text": "But"}, {"end": 253.52, "start": 252.68, "text": "if"}, {"end": 253.56, "start": 253.52, "text": "you"}, {"end": 253.92, "start": 253.56, "text": "had"}, {"end": 254.12, "start": 253.92, "text": "an"}, {"end": 255.12, "start": 254.12, "text": "algorithm"}, {"end": 255.76, "start": 255.12, "text": "that"}, {"end": 256.16, "start": 255.76, "text": "required"}, {"end": 256.48, "start": 256.16, "text": "cubic"}, {"end": 257.72, "start": 256.48, "text": "complexity,"}, {"end": 258.28, "start": 257.72, "text": "suddenly"}, {"end": 258.52, "start": 258.28, "text": "you're"}, {"end": 258.52, "start": 258.52, "text": "not"}, {"end": 258.72, "start": 258.52, "text": "talking"}, {"end": 258.92, "start": 258.72, "text": "about"}, {"end": 259.12, "start": 258.92, "text": "10"}, {"end": 259.32, "start": 259.12, "text": "raised"}, {"end": 259.44, "start": 259.32, "text": "to"}, {"end": 260.0, "start": 259.44, "text": "9."}, {"end": 260.16, "start": 260.0, "text": "You're"}, {"end": 260.32, "start": 260.16, "text": "talking"}, {"end": 260.48, "start": 260.32, "text": "about"}, {"end": 260.68, "start": 260.48, "text": "10"}, {"end": 260.92, "start": 260.68, "text": "raised"}, {"end": 260.92, "start": 260.92, "text": "to"}, {"end": 261.6, "start": 260.92, "text": "27."}, {"end": 262.08, "start": 261.6, "text": "And"}, {"end": 262.6, "start": 262.08, "text": "even"}, {"end": 262.88, "start": 262.6, "text": "current"}, {"end": 263.68, "start": 262.88, "text": "computers"}, {"end": 264.12, "start": 263.68, "text": "can't"}, {"end": 264.48, "start": 264.12, "text": "really"}, {"end": 265.32, "start": 264.48, "text": "handle"}, {"end": 265.92, "start": 265.32, "text": "those"}, {"end": 266.88, "start": 265.92, "text": "kinds"}, {"end": 267.0, "start": 266.88, "text": "of"}, {"end": 268.36, "start": 267.0, "text": "numbers."}, {"end": 268.56, "start": 268.36, "text": "So"}, {"end": 269.08, "start": 268.56, "text": "efficiency"}, {"end": 269.32, "start": 269.08, "text": "is"}, {"end": 269.32, "start": 269.32, "text": "a"}, {"end": 269.96, "start": 269.32, "text": "concern."}], "text": " But that doesn't mean that efficiency isn't of paramount concern. The fact of the matter is that you can maybe scan a billion elements in a matter of seconds. But if you had an algorithm that required cubic complexity, suddenly you're not talking about 10 raised to 9. You're talking about 10 raised to 27. And even current computers can't really handle those kinds of numbers. So efficiency is a concern."}, {"chunks": [{"end": 270.6, "start": 270.0, "text": "And"}, {"end": 271.12, "start": 270.6, "text": "as"}, {"end": 272.28, "start": 271.12, "text": "inputs"}, {"end": 272.4, "start": 272.28, "text": "get"}, {"end": 273.0, "start": 272.4, "text": "larger,"}, {"end": 273.04, "start": 273.0, "text": "it"}, {"end": 273.28, "start": 273.04, "text": "becomes"}, {"end": 273.84, "start": 273.28, "text": "more"}, {"end": 275.0, "start": 273.84, "text": "of"}, {"end": 275.28, "start": 275.0, "text": "a"}, {"end": 276.68, "start": 275.28, "text": "concern."}, {"end": 277.16, "start": 276.68, "text": "So"}, {"end": 277.28, "start": 277.16, "text": "we're"}, {"end": 278.04, "start": 277.28, "text": "concerned"}, {"end": 283.56, "start": 278.04, "text": "about"}, {"end": 284.16, "start": 283.56, "text": "efficient"}, {"end": 287.76, "start": 284.16, "text": "procedures"}, {"end": 289.52, "start": 287.76, "text": "for"}, {"end": 290.0, "start": 289.52, "text": "solving"}, {"end": 290.48, "start": 290.0, "text": "large"}, {"end": 290.68, "start": 290.48, "text": "scale"}, {"end": 291.12, "start": 290.68, "text": "problems"}, {"end": 291.12, "start": 291.12, "text": "in"}, {"end": 291.44, "start": 291.12, "text": "this"}, {"end": 294.16, "start": 291.44, "text": "class."}, {"end": 298.12, "start": 294.16, "text": "And"}, {"end": 298.64, "start": 298.12, "text": "we're"}, {"end": 299.2, "start": 298.64, "text": "concerned"}, {"end": 299.76, "start": 299.2, "text": "about"}, {"end": 299.96, "start": 299.76, "text": "scale"}], "text": " And as inputs get larger, it becomes more of a concern. So we're concerned about efficient procedures for solving large scale problems in this class. And we're concerned about scale"}, {"chunks": [{"end": 301.64, "start": 300.0, "text": "Because"}, {"end": 302.6, "start": 301.64, "text": "just"}, {"end": 303.4, "start": 302.6, "text": "as"}, {"end": 306.24, "start": 303.4, "text": "1,000"}, {"end": 307.44, "start": 306.24, "text": "was"}, {"end": 307.56, "start": 307.44, "text": "a"}, {"end": 307.72, "start": 307.56, "text": "big"}, {"end": 308.48, "start": 307.72, "text": "number"}, {"end": 308.56, "start": 308.48, "text": "a"}, {"end": 308.76, "start": 308.56, "text": "couple"}, {"end": 308.84, "start": 308.76, "text": "of"}, {"end": 309.32, "start": 308.84, "text": "decades"}, {"end": 309.52, "start": 309.32, "text": "ago,"}, {"end": 309.84, "start": 309.52, "text": "and"}, {"end": 310.36, "start": 309.84, "text": "now"}, {"end": 310.52, "start": 310.36, "text": "it's"}, {"end": 310.96, "start": 310.52, "text": "kind"}, {"end": 310.96, "start": 310.96, "text": "of"}, {"end": 310.96, "start": 310.96, "text": "a"}, {"end": 311.44, "start": 310.96, "text": "small"}, {"end": 311.88, "start": 311.44, "text": "number,"}, {"end": 312.0, "start": 311.88, "text": "it's"}, {"end": 312.32, "start": 312.0, "text": "quite"}, {"end": 312.76, "start": 312.32, "text": "possible"}, {"end": 314.36, "start": 312.76, "text": "that"}, {"end": 314.56, "start": 314.36, "text": "by"}, {"end": 314.76, "start": 314.56, "text": "the"}, {"end": 315.4, "start": 314.76, "text": "time"}, {"end": 315.56, "start": 315.4, "text": "you"}, {"end": 315.8, "start": 315.56, "text": "guys"}, {"end": 315.92, "start": 315.8, "text": "are"}, {"end": 316.36, "start": 315.92, "text": "professors"}, {"end": 316.64, "start": 316.36, "text": "teaching"}, {"end": 316.8, "start": 316.64, "text": "this"}, {"end": 317.24, "start": 316.8, "text": "class"}, {"end": 317.32, "start": 317.24, "text": "in"}, {"end": 317.56, "start": 317.32, "text": "some"}, {"end": 318.16, "start": 317.56, "text": "university"}, {"end": 318.56, "start": 318.16, "text": "that"}, {"end": 318.64, "start": 318.56, "text": "a"}, {"end": 319.36, "start": 318.64, "text": "trillion"}, {"end": 319.6, "start": 319.36, "text": "is"}, {"end": 319.6, "start": 319.6, "text": "going"}, {"end": 319.6, "start": 319.6, "text": "to"}, {"end": 319.6, "start": 319.6, "text": "be"}, {"end": 319.6, "start": 319.6, "text": "a"}, {"end": 319.84, "start": 319.6, "text": "small"}, {"end": 320.04, "start": 319.84, "text": "number."}, {"end": 320.64, "start": 320.04, "text": "And"}, {"end": 321.04, "start": 320.64, "text": "we're"}, {"end": 321.28, "start": 321.04, "text": "going"}, {"end": 321.56, "start": 321.28, "text": "to"}, {"end": 321.68, "start": 321.56, "text": "be"}, {"end": 322.32, "start": 321.68, "text": "talking"}, {"end": 322.64, "start": 322.32, "text": "about"}, {"end": 324.16, "start": 322.64, "text": "10"}, {"end": 324.36, "start": 324.16, "text": "raised"}, {"end": 324.84, "start": 324.36, "text": "to"}, {"end": 325.72, "start": 324.84, "text": "18"}, {"end": 325.92, "start": 325.72, "text": "as"}, {"end": 327.04, "start": 325.92, "text": "being"}, {"end": 327.76, "start": 327.04, "text": "something"}, {"end": 329.56, "start": 327.76, "text": "that"}, {"end": 329.68, "start": 329.56, "text": "we're"}, {"end": 329.96, "start": 329.68, "text": "concerned"}], "text": " Because just as 1,000 was a big number a couple of decades ago, and now it's kind of a small number, it's quite possible that by the time you guys are professors teaching this class in some university that a trillion is going to be a small number. And we're going to be talking about 10 raised to 18 as being something that we're concerned"}, {"chunks": [{"end": 330.2, "start": 330.0, "text": "from"}, {"end": 330.76, "start": 330.2, "text": "a"}, {"end": 331.28, "start": 330.76, "text": "standpoint"}, {"end": 331.52, "start": 331.28, "text": "of"}, {"end": 331.92, "start": 331.52, "text": "a"}, {"end": 332.24, "start": 331.92, "text": "common"}, {"end": 332.72, "start": 332.24, "text": "case"}, {"end": 332.76, "start": 332.72, "text": "input"}, {"end": 333.2, "start": 332.76, "text": "for"}, {"end": 333.36, "start": 333.2, "text": "an"}, {"end": 334.48, "start": 333.36, "text": "algorithm."}, {"end": 334.72, "start": 334.48, "text": "So"}, {"end": 335.64, "start": 334.72, "text": "scalability"}, {"end": 336.24, "start": 335.64, "text": "is"}, {"end": 337.32, "start": 336.24, "text": "important."}, {"end": 337.56, "start": 337.32, "text": "And"}, {"end": 337.56, "start": 337.56, "text": "we"}, {"end": 337.64, "start": 337.56, "text": "want"}, {"end": 338.12, "start": 337.64, "text": "to"}, {"end": 338.44, "start": 338.12, "text": "be"}, {"end": 338.72, "start": 338.44, "text": "able"}, {"end": 339.28, "start": 338.72, "text": "to"}, {"end": 340.28, "start": 339.28, "text": "track"}, {"end": 340.76, "start": 340.28, "text": "how"}, {"end": 340.96, "start": 340.76, "text": "our"}, {"end": 341.32, "start": 340.96, "text": "algorithms"}, {"end": 341.44, "start": 341.32, "text": "are"}, {"end": 341.52, "start": 341.44, "text": "going"}, {"end": 341.96, "start": 341.52, "text": "to"}, {"end": 342.24, "start": 341.96, "text": "do"}, {"end": 342.6, "start": 342.24, "text": "as"}, {"end": 342.84, "start": 342.6, "text": "inputs"}, {"end": 343.04, "start": 342.84, "text": "get"}, {"end": 343.6, "start": 343.04, "text": "larger"}, {"end": 346.32, "start": 343.6, "text": "and"}, {"end": 347.2, "start": 346.32, "text": "larger."}, {"end": 348.04, "start": 347.2, "text": "You're"}, {"end": 348.24, "start": 348.04, "text": "going"}, {"end": 348.68, "start": 348.24, "text": "to"}, {"end": 349.08, "start": 348.68, "text": "learn"}, {"end": 349.36, "start": 349.08, "text": "a"}, {"end": 349.92, "start": 349.36, "text": "bunch"}, {"end": 350.24, "start": 349.92, "text": "of"}, {"end": 350.32, "start": 350.24, "text": "different"}, {"end": 350.8, "start": 350.32, "text": "data"}, {"end": 352.16, "start": 350.8, "text": "structures."}, {"end": 352.28, "start": 352.16, "text": "We'll"}, {"end": 352.88, "start": 352.28, "text": "call"}, {"end": 353.2, "start": 352.88, "text": "them"}, {"end": 354.6, "start": 353.2, "text": "classic"}, {"end": 355.08, "start": 354.6, "text": "data"}, {"end": 356.64, "start": 355.08, "text": "structures,"}, {"end": 357.36, "start": 356.64, "text": "like"}, {"end": 357.76, "start": 357.36, "text": "binary"}, {"end": 358.2, "start": 357.76, "text": "search"}, {"end": 359.64, "start": 358.2, "text": "trees,"}, {"end": 359.96, "start": 359.64, "text": "hash"}], "text": " from a standpoint of a common case input for an algorithm. So scalability is important. And we want to be able to track how our algorithms are going to do as inputs get larger and larger. You're going to learn a bunch of different data structures. We'll call them classic data structures, like binary search trees, hash"}, {"chunks": [{"end": 361.28, "start": 360.0, "text": "Tables"}, {"end": 361.52, "start": 361.28, "text": "that"}, {"end": 361.64, "start": 361.52, "text": "are"}, {"end": 361.68, "start": 361.64, "text": "called"}, {"end": 362.16, "start": 361.68, "text": "dictionaries"}, {"end": 362.24, "start": 362.16, "text": "in"}, {"end": 362.6, "start": 362.24, "text": "Python."}, {"end": 364.04, "start": 362.6, "text": "And"}, {"end": 365.92, "start": 364.04, "text": "data"}, {"end": 366.56, "start": 365.92, "text": "structures"}, {"end": 367.04, "start": 366.56, "text": "such"}, {"end": 367.68, "start": 367.04, "text": "as"}, {"end": 368.32, "start": 367.68, "text": "balanced"}, {"end": 368.6, "start": 368.32, "text": "binary"}, {"end": 368.88, "start": 368.6, "text": "search"}, {"end": 369.32, "start": 368.88, "text": "trees"}, {"end": 369.88, "start": 369.32, "text": "that"}, {"end": 369.88, "start": 369.88, "text": "are"}, {"end": 370.2, "start": 369.88, "text": "more"}, {"end": 370.52, "start": 370.2, "text": "efficient"}, {"end": 370.8, "start": 370.52, "text": "than"}, {"end": 370.96, "start": 370.8, "text": "just"}, {"end": 371.04, "start": 370.96, "text": "the"}, {"end": 371.4, "start": 371.04, "text": "regular"}, {"end": 371.68, "start": 371.4, "text": "binary"}, {"end": 372.0, "start": 371.68, "text": "search"}, {"end": 373.08, "start": 372.0, "text": "trees."}, {"end": 373.24, "start": 373.08, "text": "And"}, {"end": 373.44, "start": 373.24, "text": "these"}, {"end": 373.6, "start": 373.44, "text": "are"}, {"end": 373.64, "start": 373.6, "text": "all"}, {"end": 373.8, "start": 373.64, "text": "data"}, {"end": 374.28, "start": 373.8, "text": "structures"}, {"end": 375.44, "start": 374.28, "text": "that"}, {"end": 375.76, "start": 375.44, "text": "were"}, {"end": 377.08, "start": 375.76, "text": "invented"}, {"end": 377.32, "start": 377.08, "text": "many"}, {"end": 377.84, "start": 377.32, "text": "decades"}, {"end": 378.48, "start": 377.84, "text": "ago,"}, {"end": 378.6, "start": 378.48, "text": "but"}, {"end": 378.84, "start": 378.6, "text": "they've"}, {"end": 379.0, "start": 378.84, "text": "stood"}, {"end": 379.08, "start": 379.0, "text": "the"}, {"end": 379.48, "start": 379.08, "text": "test"}, {"end": 379.48, "start": 379.48, "text": "of"}, {"end": 380.04, "start": 379.48, "text": "time."}, {"end": 380.8, "start": 380.04, "text": "And"}, {"end": 381.4, "start": 380.8, "text": "they"}, {"end": 381.72, "start": 381.4, "text": "continue"}, {"end": 381.88, "start": 381.72, "text": "to"}, {"end": 382.2, "start": 381.88, "text": "be"}, {"end": 382.6, "start": 382.2, "text": "useful."}, {"end": 382.64, "start": 382.6, "text": "We're"}, {"end": 383.64, "start": 382.64, "text": "going"}, {"end": 383.96, "start": 383.64, "text": "to"}, {"end": 384.36, "start": 383.96, "text": "augment"}, {"end": 384.6, "start": 384.36, "text": "these"}, {"end": 385.0, "start": 384.6, "text": "data"}, {"end": 385.36, "start": 385.0, "text": "structures"}, {"end": 385.4, "start": 385.36, "text": "in"}, {"end": 385.76, "start": 385.4, "text": "various"}, {"end": 386.12, "start": 385.76, "text": "ways"}, {"end": 386.24, "start": 386.12, "text": "to"}, {"end": 386.4, "start": 386.24, "text": "make"}, {"end": 386.6, "start": 386.4, "text": "them"}, {"end": 387.0, "start": 386.6, "text": "more"}, {"end": 387.96, "start": 387.0, "text": "efficient"}, {"end": 388.32, "start": 387.96, "text": "for"}, {"end": 388.68, "start": 388.32, "text": "certain"}, {"end": 389.12, "start": 388.68, "text": "kinds"}, {"end": 389.2, "start": 389.12, "text": "of"}, {"end": 389.96, "start": 389.2, "text": "problems."}], "text": " Tables that are called dictionaries in Python. And data structures such as balanced binary search trees that are more efficient than just the regular binary search trees. And these are all data structures that were invented many decades ago, but they've stood the test of time. And they continue to be useful. We're going to augment these data structures in various ways to make them more efficient for certain kinds of problems."}, {"chunks": [{"end": 390.32, "start": 390.0, "text": "And"}, {"end": 390.96, "start": 390.32, "text": "while"}, {"end": 391.48, "start": 390.96, "text": "you're"}, {"end": 391.6, "start": 391.48, "text": "not"}, {"end": 392.08, "start": 391.6, "text": "going"}, {"end": 392.12, "start": 392.08, "text": "to"}, {"end": 392.16, "start": 392.12, "text": "be"}, {"end": 392.48, "start": 392.16, "text": "doing"}, {"end": 392.64, "start": 392.48, "text": "a"}, {"end": 392.88, "start": 392.64, "text": "whole"}, {"end": 393.4, "start": 392.88, "text": "lot"}, {"end": 393.48, "start": 393.4, "text": "of"}, {"end": 393.96, "start": 393.48, "text": "algorithm"}, {"end": 394.52, "start": 393.96, "text": "design"}, {"end": 394.52, "start": 394.52, "text": "in"}, {"end": 394.72, "start": 394.52, "text": "this"}, {"end": 395.32, "start": 394.72, "text": "class,"}, {"end": 395.72, "start": 395.32, "text": "you"}, {"end": 396.08, "start": 395.72, "text": "will"}, {"end": 396.12, "start": 396.08, "text": "be"}, {"end": 396.36, "start": 396.12, "text": "doing"}, {"end": 396.68, "start": 396.36, "text": "some"}, {"end": 397.2, "start": 396.68, "text": "design"}, {"end": 397.36, "start": 397.2, "text": "and"}, {"end": 397.48, "start": 397.36, "text": "a"}, {"end": 397.92, "start": 397.48, "text": "whole"}, {"end": 398.36, "start": 397.92, "text": "lot"}, {"end": 400.96, "start": 398.36, "text": "of"}, {"end": 402.0, "start": 400.96, "text": "analysis."}, {"end": 402.24, "start": 402.0, "text": "The"}, {"end": 403.04, "start": 402.24, "text": "class"}, {"end": 403.4, "start": 403.04, "text": "following"}, {"end": 403.6, "start": 403.4, "text": "this"}, {"end": 404.16, "start": 403.6, "text": "one,"}, {"end": 405.12, "start": 404.16, "text": "6046,"}, {"end": 405.56, "start": 405.12, "text": "Design"}, {"end": 406.12, "start": 405.56, "text": "Analysis"}, {"end": 406.4, "start": 406.12, "text": "of"}, {"end": 407.28, "start": 406.4, "text": "Algorithms,"}, {"end": 407.44, "start": 407.28, "text": "is"}, {"end": 407.44, "start": 407.44, "text": "a"}, {"end": 408.04, "start": 407.44, "text": "class"}, {"end": 408.36, "start": 408.04, "text": "that"}, {"end": 408.48, "start": 408.36, "text": "you"}, {"end": 408.64, "start": 408.48, "text": "should"}, {"end": 408.92, "start": 408.64, "text": "take"}, {"end": 409.28, "start": 408.92, "text": "if"}, {"end": 409.72, "start": 409.28, "text": "you"}, {"end": 409.76, "start": 409.72, "text": "like"}, {"end": 409.76, "start": 409.76, "text": "this"}, {"end": 409.88, "start": 409.76, "text": "one."}, {"end": 410.92, "start": 409.88, "text": "And"}, {"end": 411.28, "start": 410.92, "text": "you"}, {"end": 412.0, "start": 411.28, "text": "can"}, {"end": 412.08, "start": 412.0, "text": "do"}, {"end": 412.36, "start": 412.08, "text": "a"}, {"end": 412.6, "start": 412.36, "text": "whole"}, {"end": 413.08, "start": 412.6, "text": "lot"}, {"end": 413.32, "start": 413.08, "text": "more"}, {"end": 414.12, "start": 413.32, "text": "design"}, {"end": 414.28, "start": 414.12, "text": "of"}, {"end": 414.92, "start": 414.28, "text": "algorithms"}, {"end": 415.04, "start": 414.92, "text": "in"}, {"end": 417.12, "start": 415.04, "text": "6046."}, {"end": 417.52, "start": 417.12, "text": "But"}, {"end": 417.68, "start": 417.52, "text": "you"}, {"end": 417.92, "start": 417.68, "text": "will"}, {"end": 418.32, "start": 417.92, "text": "look"}, {"end": 418.52, "start": 418.32, "text": "at"}, {"end": 419.0, "start": 418.52, "text": "classic"}, {"end": 419.28, "start": 419.0, "text": "data"}, {"end": 419.96, "start": 419.28, "text": "structures"}], "text": " And while you're not going to be doing a whole lot of algorithm design in this class, you will be doing some design and a whole lot of analysis. The class following this one, 6046, Design Analysis of Algorithms, is a class that you should take if you like this one. And you can do a whole lot more design of algorithms in 6046. But you will look at classic data structures"}, {"chunks": [{"end": 420.76, "start": 420.0, "text": "and"}, {"end": 421.2, "start": 420.76, "text": "classical"}, {"end": 423.64, "start": 421.2, "text": "algorithms"}, {"end": 424.56, "start": 423.64, "text": "for"}, {"end": 424.88, "start": 424.56, "text": "these"}, {"end": 425.28, "start": 424.88, "text": "data"}, {"end": 426.12, "start": 425.28, "text": "structures,"}, {"end": 426.6, "start": 426.12, "text": "including"}, {"end": 426.92, "start": 426.6, "text": "things"}, {"end": 428.44, "start": 426.92, "text": "like"}, {"end": 429.16, "start": 428.44, "text": "sorting"}, {"end": 429.28, "start": 429.16, "text": "and"}, {"end": 430.32, "start": 429.28, "text": "matching"}, {"end": 430.6, "start": 430.32, "text": "and"}, {"end": 430.96, "start": 430.6, "text": "so"}, {"end": 432.4, "start": 430.96, "text": "on."}, {"end": 432.76, "start": 432.4, "text": "And"}, {"end": 432.8, "start": 432.76, "text": "one"}, {"end": 432.8, "start": 432.8, "text": "of"}, {"end": 433.04, "start": 432.8, "text": "the"}, {"end": 433.48, "start": 433.04, "text": "nice"}, {"end": 433.68, "start": 433.48, "text": "things"}, {"end": 433.84, "start": 433.68, "text": "about"}, {"end": 434.0, "start": 433.84, "text": "this"}, {"end": 437.16, "start": 434.0, "text": "class"}, {"end": 437.44, "start": 437.16, "text": "is"}, {"end": 437.64, "start": 437.44, "text": "that"}, {"end": 437.8, "start": 437.64, "text": "you'll"}, {"end": 437.88, "start": 437.8, "text": "be"}, {"end": 438.16, "start": 437.88, "text": "doing"}, {"end": 438.56, "start": 438.16, "text": "real"}, {"end": 441.08, "start": 438.56, "text": "implementations"}, {"end": 441.36, "start": 441.08, "text": "of"}, {"end": 441.56, "start": 441.36, "text": "these"}, {"end": 442.0, "start": 441.56, "text": "data"}, {"end": 442.88, "start": 442.0, "text": "structures"}, {"end": 444.64, "start": 442.88, "text": "and"}, {"end": 448.24, "start": 444.64, "text": "algorithms"}, {"end": 448.52, "start": 448.24, "text": "in"}, {"end": 449.96, "start": 448.52, "text": "Python."}], "text": " and classical algorithms for these data structures, including things like sorting and matching and so on. And one of the nice things about this class is that you'll be doing real implementations of these data structures and algorithms in Python."}, {"chunks": [{"end": 450.08, "start": 450.0, "text": "Each"}, {"end": 450.16, "start": 450.08, "text": "of"}, {"end": 450.52, "start": 450.16, "text": "the"}, {"end": 450.88, "start": 450.52, "text": "problem"}, {"end": 452.32, "start": 450.88, "text": "sets"}, {"end": 452.64, "start": 452.32, "text": "in"}, {"end": 452.96, "start": 452.64, "text": "this"}, {"end": 454.48, "start": 452.96, "text": "class"}, {"end": 454.84, "start": 454.48, "text": "are"}, {"end": 455.48, "start": 454.84, "text": "going"}, {"end": 455.88, "start": 455.48, "text": "to"}, {"end": 456.44, "start": 455.88, "text": "have"}, {"end": 457.88, "start": 456.44, "text": "both"}, {"end": 458.0, "start": 457.88, "text": "a"}, {"end": 458.64, "start": 458.0, "text": "theory"}, {"end": 458.96, "start": 458.64, "text": "part"}, {"end": 459.32, "start": 458.96, "text": "to"}, {"end": 459.32, "start": 459.32, "text": "them"}, {"end": 459.92, "start": 459.32, "text": "and"}, {"end": 460.16, "start": 459.92, "text": "a"}, {"end": 460.64, "start": 460.16, "text": "programming"}, {"end": 460.88, "start": 460.64, "text": "part"}, {"end": 461.0, "start": 460.88, "text": "to"}, {"end": 461.0, "start": 461.0, "text": "them."}, {"end": 461.76, "start": 461.0, "text": "So"}, {"end": 461.8, "start": 461.76, "text": "hopefully"}, {"end": 462.28, "start": 461.8, "text": "it'll"}, {"end": 462.72, "start": 462.28, "text": "all"}, {"end": 462.96, "start": 462.72, "text": "tie"}, {"end": 463.2, "start": 462.96, "text": "together."}, {"end": 463.44, "start": 463.2, "text": "The"}, {"end": 463.8, "start": 463.44, "text": "kinds"}, {"end": 463.8, "start": 463.8, "text": "of"}, {"end": 464.04, "start": 463.8, "text": "things"}, {"end": 464.08, "start": 464.04, "text": "we're"}, {"end": 464.24, "start": 464.08, "text": "going"}, {"end": 464.28, "start": 464.24, "text": "to"}, {"end": 464.32, "start": 464.28, "text": "be"}, {"end": 464.76, "start": 464.32, "text": "talking"}, {"end": 464.92, "start": 464.76, "text": "about"}, {"end": 465.04, "start": 464.92, "text": "in"}, {"end": 466.08, "start": 465.04, "text": "lectures"}, {"end": 466.48, "start": 466.08, "text": "and"}, {"end": 467.92, "start": 466.48, "text": "recitations"}, {"end": 468.48, "start": 467.92, "text": "are"}, {"end": 468.76, "start": 468.48, "text": "going"}, {"end": 468.96, "start": 468.76, "text": "to"}, {"end": 469.48, "start": 468.96, "text": "be"}, {"end": 469.88, "start": 469.48, "text": "directly"}, {"end": 470.48, "start": 469.88, "text": "connected"}, {"end": 471.32, "start": 470.48, "text": "to"}, {"end": 471.48, "start": 471.32, "text": "the"}, {"end": 471.72, "start": 471.48, "text": "theory"}, {"end": 472.08, "start": 471.72, "text": "parts"}, {"end": 472.08, "start": 472.08, "text": "of"}, {"end": 472.16, "start": 472.08, "text": "the"}, {"end": 472.44, "start": 472.16, "text": "problem"}, {"end": 473.2, "start": 472.44, "text": "sets."}, {"end": 473.24, "start": 473.2, "text": "And"}, {"end": 473.44, "start": 473.24, "text": "you'll"}, {"end": 473.56, "start": 473.44, "text": "be"}, {"end": 474.56, "start": 473.56, "text": "programming"}, {"end": 474.96, "start": 474.56, "text": "the"}, {"end": 475.08, "start": 474.96, "text": "algorithms"}, {"end": 475.2, "start": 475.08, "text": "that"}, {"end": 475.28, "start": 475.2, "text": "we"}, {"end": 475.6, "start": 475.28, "text": "talk"}, {"end": 475.96, "start": 475.6, "text": "about"}, {"end": 475.96, "start": 475.96, "text": "in"}, {"end": 476.44, "start": 475.96, "text": "lecture"}, {"end": 476.56, "start": 476.44, "text": "or"}, {"end": 476.92, "start": 476.56, "text": "augmenting"}, {"end": 477.64, "start": 476.92, "text": "them,"}, {"end": 477.96, "start": 477.64, "text": "running"}, {"end": 478.24, "start": 477.96, "text": "them,"}, {"end": 478.92, "start": 478.24, "text": "figuring"}, {"end": 479.52, "start": 478.92, "text": "out"}, {"end": 479.96, "start": 479.52, "text": "whether"}], "text": " Each of the problem sets in this class are going to have both a theory part to them and a programming part to them. So hopefully it'll all tie together. The kinds of things we're going to be talking about in lectures and recitations are going to be directly connected to the theory parts of the problem sets. And you'll be programming the algorithms that we talk about in lecture or augmenting them, running them, figuring out whether"}, {"chunks": [{"end": 480.52, "start": 480.0, "text": "And"}, {"end": 480.72, "start": 480.52, "text": "they"}, {"end": 480.88, "start": 480.72, "text": "work"}, {"end": 481.12, "start": 480.88, "text": "well"}, {"end": 481.32, "start": 481.12, "text": "on"}, {"end": 482.04, "start": 481.32, "text": "large"}, {"end": 482.72, "start": 482.04, "text": "inputs"}, {"end": 486.08, "start": 482.72, "text": "or"}, {"end": 486.52, "start": 486.08, "text": "not."}, {"end": 487.0, "start": 486.52, "text": "So"}, {"end": 487.08, "start": 487.0, "text": "let"}, {"end": 487.16, "start": 487.08, "text": "me"}, {"end": 487.64, "start": 487.16, "text": "talk"}, {"end": 487.76, "start": 487.64, "text": "a"}, {"end": 488.08, "start": 487.76, "text": "little"}, {"end": 488.16, "start": 488.08, "text": "bit"}, {"end": 488.8, "start": 488.16, "text": "about"}, {"end": 488.96, "start": 488.8, "text": "the"}, {"end": 489.52, "start": 488.96, "text": "modules"}, {"end": 489.56, "start": 489.52, "text": "in"}, {"end": 489.72, "start": 489.56, "text": "this"}, {"end": 490.2, "start": 489.72, "text": "class"}, {"end": 490.32, "start": 490.2, "text": "and"}, {"end": 490.4, "start": 490.32, "text": "the"}, {"end": 490.72, "start": 490.4, "text": "problem"}, {"end": 491.24, "start": 490.72, "text": "sets."}, {"end": 491.56, "start": 491.24, "text": "And"}, {"end": 491.68, "start": 491.56, "text": "we"}, {"end": 491.84, "start": 491.68, "text": "hope"}, {"end": 492.16, "start": 491.84, "text": "that"}, {"end": 492.28, "start": 492.16, "text": "these"}, {"end": 492.56, "start": 492.28, "text": "problem"}, {"end": 492.96, "start": 492.56, "text": "sets"}, {"end": 493.12, "start": 492.96, "text": "are"}, {"end": 493.32, "start": 493.12, "text": "going"}, {"end": 493.32, "start": 493.32, "text": "to"}, {"end": 493.68, "start": 493.32, "text": "be"}, {"end": 494.0, "start": 493.68, "text": "fun"}, {"end": 494.2, "start": 494.0, "text": "for"}, {"end": 494.4, "start": 494.2, "text": "you."}, {"end": 495.2, "start": 494.4, "text": "And"}, {"end": 495.92, "start": 495.2, "text": "by"}, {"end": 496.24, "start": 495.92, "text": "fun,"}, {"end": 496.52, "start": 496.24, "text": "I"}, {"end": 496.84, "start": 496.52, "text": "don't"}, {"end": 497.24, "start": 496.84, "text": "mean"}, {"end": 498.68, "start": 497.24, "text": "easy."}, {"end": 499.4, "start": 498.68, "text": "I"}, {"end": 499.96, "start": 499.4, "text": "mean"}, {"end": 500.84, "start": 499.96, "text": "challenging"}, {"end": 500.88, "start": 500.84, "text": "and"}, {"end": 501.6, "start": 500.88, "text": "worthwhile."}, {"end": 502.0, "start": 501.6, "text": "So"}, {"end": 502.0, "start": 502.0, "text": "at"}, {"end": 502.12, "start": 502.0, "text": "the"}, {"end": 502.44, "start": 502.12, "text": "end"}, {"end": 502.6, "start": 502.44, "text": "of"}, {"end": 502.6, "start": 502.6, "text": "it,"}, {"end": 502.6, "start": 502.6, "text": "you"}, {"end": 502.8, "start": 502.6, "text": "feel"}, {"end": 503.04, "start": 502.8, "text": "like"}, {"end": 503.2, "start": 503.04, "text": "you've"}, {"end": 503.44, "start": 503.2, "text": "learned"}, {"end": 503.68, "start": 503.44, "text": "something."}, {"end": 504.32, "start": 503.68, "text": "And"}, {"end": 504.92, "start": 504.32, "text": "you've"}, {"end": 505.24, "start": 504.92, "text": "had"}, {"end": 505.36, "start": 505.24, "text": "some"}, {"end": 506.72, "start": 505.36, "text": "fun"}, {"end": 506.92, "start": 506.72, "text": "along"}, {"end": 509.08, "start": 506.92, "text": "the"}, {"end": 509.96, "start": 509.08, "text": "way."}], "text": " And they work well on large inputs or not. So let me talk a little bit about the modules in this class and the problem sets. And we hope that these problem sets are going to be fun for you. And by fun, I don't mean easy. I mean challenging and worthwhile. So at the end of it, you feel like you've learned something. And you've had some fun along the way."}, {"chunks": [{"end": 514.48, "start": 510.0, "text": "We"}, {"end": 517.44, "start": 514.48, "text": "have"}, {"end": 519.04, "start": 517.44, "text": "eight"}, {"end": 519.84, "start": 519.04, "text": "modules"}, {"end": 519.92, "start": 519.84, "text": "in"}, {"end": 521.36, "start": 519.92, "text": "the"}, {"end": 521.8, "start": 521.36, "text": "class,"}, {"end": 522.04, "start": 521.8, "text": "each"}, {"end": 522.08, "start": 522.04, "text": "of"}, {"end": 523.2, "start": 522.08, "text": "which,"}, {"end": 523.6, "start": 523.2, "text": "roughly"}, {"end": 524.04, "start": 523.6, "text": "speaking,"}, {"end": 524.44, "start": 524.04, "text": "has"}, {"end": 524.52, "start": 524.44, "text": "a"}, {"end": 524.84, "start": 524.52, "text": "problem"}, {"end": 525.04, "start": 524.84, "text": "set"}, {"end": 525.48, "start": 525.04, "text": "associated"}, {"end": 525.64, "start": 525.48, "text": "with"}, {"end": 526.84, "start": 525.64, "text": "it."}, {"end": 527.04, "start": 526.84, "text": "The"}, {"end": 527.2, "start": 527.04, "text": "first"}, {"end": 527.56, "start": 527.2, "text": "of"}, {"end": 529.92, "start": 527.56, "text": "these"}, {"end": 530.28, "start": 529.92, "text": "is"}, {"end": 530.44, "start": 530.28, "text": "what"}, {"end": 530.68, "start": 530.44, "text": "we"}, {"end": 531.44, "start": 530.68, "text": "call"}, {"end": 532.32, "start": 531.44, "text": "algorithmic"}, {"end": 534.08, "start": 532.32, "text": "thinking."}, {"end": 535.56, "start": 534.08, "text": "And"}, {"end": 536.0, "start": 535.56, "text": "we'll"}, {"end": 536.24, "start": 536.0, "text": "kick"}, {"end": 537.76, "start": 536.24, "text": "start"}, {"end": 538.8, "start": 537.76, "text": "that"}, {"end": 539.08, "start": 538.8, "text": "one"}, {"end": 539.96, "start": 539.08, "text": "today."}], "text": " We have eight modules in the class, each of which, roughly speaking, has a problem set associated with it. The first of these is what we call algorithmic thinking. And we'll kick start that one today."}, {"chunks": [{"end": 540.24, "start": 540.0, "text": "A"}, {"end": 540.56, "start": 540.24, "text": "particular"}, {"end": 540.88, "start": 540.56, "text": "problem,"}, {"end": 541.0, "start": 540.88, "text": "as"}, {"end": 541.12, "start": 541.0, "text": "I"}, {"end": 541.44, "start": 541.12, "text": "mentioned,"}, {"end": 541.56, "start": 541.44, "text": "of"}, {"end": 541.76, "start": 541.56, "text": "peak"}, {"end": 542.8, "start": 541.76, "text": "finding."}, {"end": 543.2, "start": 542.8, "text": "And"}, {"end": 543.36, "start": 543.2, "text": "as"}, {"end": 543.48, "start": 543.36, "text": "part"}, {"end": 543.68, "start": 543.48, "text": "of"}, {"end": 544.04, "start": 543.68, "text": "this,"}, {"end": 544.76, "start": 544.04, "text": "you're"}, {"end": 544.88, "start": 544.76, "text": "going"}, {"end": 544.88, "start": 544.88, "text": "to"}, {"end": 544.88, "start": 544.88, "text": "have"}, {"end": 545.04, "start": 544.88, "text": "a"}, {"end": 545.32, "start": 545.04, "text": "problem"}, {"end": 545.68, "start": 545.32, "text": "set"}, {"end": 545.92, "start": 545.68, "text": "that's"}, {"end": 546.08, "start": 545.92, "text": "going"}, {"end": 546.08, "start": 546.08, "text": "to"}, {"end": 546.4, "start": 546.08, "text": "go"}, {"end": 546.4, "start": 546.4, "text": "out"}, {"end": 546.84, "start": 546.4, "text": "today"}, {"end": 547.16, "start": 546.84, "text": "as"}, {"end": 547.16, "start": 547.16, "text": "well."}, {"end": 547.88, "start": 547.16, "text": "And"}, {"end": 548.12, "start": 547.88, "text": "you'll"}, {"end": 548.76, "start": 548.12, "text": "find"}, {"end": 549.0, "start": 548.76, "text": "that"}, {"end": 549.24, "start": 549.0, "text": "in"}, {"end": 549.68, "start": 549.24, "text": "this"}, {"end": 549.96, "start": 549.68, "text": "problem"}, {"end": 550.68, "start": 549.96, "text": "set,"}, {"end": 550.92, "start": 550.68, "text": "some"}, {"end": 552.28, "start": 550.92, "text": "of"}, {"end": 552.76, "start": 552.28, "text": "these"}, {"end": 553.32, "start": 552.76, "text": "algorithms"}, {"end": 553.32, "start": 553.32, "text": "I've"}, {"end": 553.4, "start": 553.32, "text": "talked"}, {"end": 553.76, "start": 553.4, "text": "about"}, {"end": 554.2, "start": 553.76, "text": "today"}, {"end": 554.4, "start": 554.2, "text": "will"}, {"end": 554.48, "start": 554.4, "text": "be"}, {"end": 554.92, "start": 554.48, "text": "coded"}, {"end": 554.92, "start": 554.92, "text": "in"}, {"end": 555.28, "start": 554.92, "text": "Python"}, {"end": 555.6, "start": 555.28, "text": "and"}, {"end": 555.84, "start": 555.6, "text": "given"}, {"end": 556.44, "start": 555.84, "text": "to"}, {"end": 557.04, "start": 556.44, "text": "you."}, {"end": 557.12, "start": 557.04, "text": "A"}, {"end": 557.4, "start": 557.12, "text": "couple"}, {"end": 557.64, "start": 557.4, "text": "of"}, {"end": 558.0, "start": 557.64, "text": "them"}, {"end": 558.36, "start": 558.0, "text": "are"}, {"end": 558.6, "start": 558.36, "text": "going"}, {"end": 559.64, "start": 558.6, "text": "to"}, {"end": 559.76, "start": 559.64, "text": "have"}, {"end": 560.16, "start": 559.76, "text": "bugs"}, {"end": 560.24, "start": 560.16, "text": "in"}, {"end": 560.24, "start": 560.24, "text": "them."}, {"end": 560.64, "start": 560.24, "text": "You'll"}, {"end": 560.88, "start": 560.64, "text": "have"}, {"end": 561.12, "start": 560.88, "text": "to"}, {"end": 562.0, "start": 561.12, "text": "analyze"}, {"end": 562.44, "start": 562.0, "text": "the"}, {"end": 562.92, "start": 562.44, "text": "complexity"}, {"end": 563.0, "start": 562.92, "text": "of"}, {"end": 563.2, "start": 563.0, "text": "these"}, {"end": 564.36, "start": 563.2, "text": "algorithms,"}, {"end": 564.68, "start": 564.36, "text": "figure"}, {"end": 565.2, "start": 564.68, "text": "out"}, {"end": 565.4, "start": 565.2, "text": "which"}, {"end": 565.8, "start": 565.4, "text": "ones"}, {"end": 566.12, "start": 565.8, "text": "are"}, {"end": 566.36, "start": 566.12, "text": "correct"}, {"end": 566.44, "start": 566.36, "text": "and"}, {"end": 566.92, "start": 566.44, "text": "efficient,"}, {"end": 567.88, "start": 566.92, "text": "and"}, {"end": 567.96, "start": 567.88, "text": "write"}, {"end": 568.16, "start": 567.96, "text": "a"}, {"end": 568.52, "start": 568.16, "text": "proof"}, {"end": 568.92, "start": 568.52, "text": "for"}, {"end": 569.08, "start": 568.92, "text": "one"}, {"end": 569.08, "start": 569.08, "text": "of"}, {"end": 569.96, "start": 569.08, "text": "them."}], "text": " A particular problem, as I mentioned, of peak finding. And as part of this, you're going to have a problem set that's going to go out today as well. And you'll find that in this problem set, some of these algorithms I've talked about today will be coded in Python and given to you. A couple of them are going to have bugs in them. You'll have to analyze the complexity of these algorithms, figure out which ones are correct and efficient, and write a proof for one of them."}, {"chunks": [{"end": 570.12, "start": 570.0, "text": "So"}, {"end": 570.4, "start": 570.12, "text": "that's"}, {"end": 570.8, "start": 570.4, "text": "sort"}, {"end": 571.68, "start": 570.8, "text": "of"}, {"end": 571.92, "start": 571.68, "text": "an"}, {"end": 572.52, "start": 571.92, "text": "example"}, {"end": 572.8, "start": 572.52, "text": "problem"}, {"end": 573.16, "start": 572.8, "text": "set."}, {"end": 573.36, "start": 573.16, "text": "And"}, {"end": 573.72, "start": 573.36, "text": "you"}, {"end": 574.4, "start": 573.72, "text": "can"}, {"end": 575.36, "start": 574.4, "text": "expect"}, {"end": 576.44, "start": 575.36, "text": "that"}, {"end": 576.84, "start": 576.44, "text": "most"}, {"end": 576.84, "start": 576.84, "text": "of"}, {"end": 576.96, "start": 576.84, "text": "the"}, {"end": 577.24, "start": 576.96, "text": "problem"}, {"end": 577.68, "start": 577.24, "text": "sets"}, {"end": 577.8, "start": 577.68, "text": "are"}, {"end": 577.88, "start": 577.8, "text": "going"}, {"end": 577.96, "start": 577.88, "text": "to"}, {"end": 578.6, "start": 577.96, "text": "follow"}, {"end": 578.8, "start": 578.6, "text": "that"}, {"end": 579.16, "start": 578.8, "text": "sort"}, {"end": 579.28, "start": 579.16, "text": "of"}, {"end": 580.52, "start": 579.28, "text": "template."}, {"end": 581.04, "start": 580.52, "text": "So"}, {"end": 581.08, "start": 581.04, "text": "you'll"}, {"end": 581.48, "start": 581.08, "text": "get"}, {"end": 582.2, "start": 581.48, "text": "a"}, {"end": 582.64, "start": 582.2, "text": "better"}, {"end": 582.96, "start": 582.64, "text": "sense"}, {"end": 582.96, "start": 582.96, "text": "of"}, {"end": 583.6, "start": 582.96, "text": "this"}, {"end": 583.84, "start": 583.6, "text": "by"}, {"end": 583.96, "start": 583.84, "text": "the"}, {"end": 584.72, "start": 583.96, "text": "end"}, {"end": 584.76, "start": 584.72, "text": "of"}, {"end": 584.92, "start": 584.76, "text": "the"}, {"end": 585.16, "start": 584.92, "text": "day"}, {"end": 585.44, "start": 585.16, "text": "today,"}, {"end": 586.04, "start": 585.44, "text": "for"}, {"end": 586.64, "start": 586.04, "text": "sure,"}, {"end": 587.08, "start": 586.64, "text": "or"}, {"end": 587.16, "start": 587.08, "text": "a"}, {"end": 587.52, "start": 587.16, "text": "concrete"}, {"end": 588.2, "start": 587.52, "text": "sense"}, {"end": 588.36, "start": 588.2, "text": "of"}, {"end": 588.44, "start": 588.36, "text": "this,"}, {"end": 588.72, "start": 588.44, "text": "because"}, {"end": 588.88, "start": 588.72, "text": "we'll"}, {"end": 588.96, "start": 588.88, "text": "be"}, {"end": 589.24, "start": 588.96, "text": "done"}, {"end": 589.28, "start": 589.24, "text": "with"}, {"end": 589.88, "start": 589.28, "text": "lecture"}, {"end": 590.2, "start": 589.88, "text": "and"}, {"end": 590.64, "start": 590.2, "text": "you'll"}, {"end": 590.8, "start": 590.64, "text": "see"}, {"end": 590.96, "start": 590.8, "text": "your"}, {"end": 591.2, "start": 590.96, "text": "first"}, {"end": 591.44, "start": 591.2, "text": "problem"}, {"end": 592.24, "start": 591.44, "text": "set."}, {"end": 592.68, "start": 592.24, "text": "We're"}, {"end": 592.84, "start": 592.68, "text": "going"}, {"end": 592.88, "start": 592.84, "text": "to"}, {"end": 593.04, "start": 592.88, "text": "be"}, {"end": 593.32, "start": 593.04, "text": "doing"}, {"end": 593.64, "start": 593.32, "text": "a"}, {"end": 594.24, "start": 593.64, "text": "module"}, {"end": 594.48, "start": 594.24, "text": "on"}, {"end": 595.36, "start": 594.48, "text": "sorting"}, {"end": 595.52, "start": 595.36, "text": "in"}, {"end": 597.52, "start": 595.52, "text": "trees."}, {"end": 597.92, "start": 597.52, "text": "Sorting"}, {"end": 598.32, "start": 597.92, "text": "you"}, {"end": 598.56, "start": 598.32, "text": "know"}, {"end": 598.92, "start": 598.56, "text": "about,"}, {"end": 599.16, "start": 598.92, "text": "sorting"}, {"end": 599.28, "start": 599.16, "text": "a"}, {"end": 599.6, "start": 599.28, "text": "bunch"}, {"end": 599.72, "start": 599.6, "text": "of"}, {"end": 599.96, "start": 599.72, "text": "numbers."}], "text": " So that's sort of an example problem set. And you can expect that most of the problem sets are going to follow that sort of template. So you'll get a better sense of this by the end of the day today, for sure, or a concrete sense of this, because we'll be done with lecture and you'll see your first problem set. We're going to be doing a module on sorting in trees. Sorting you know about, sorting a bunch of numbers."}, {"chunks": [{"end": 600.08, "start": 600.0, "text": "Imagine"}, {"end": 600.76, "start": 600.08, "text": "if"}, {"end": 600.84, "start": 600.76, "text": "you"}, {"end": 601.16, "start": 600.84, "text": "had"}, {"end": 601.4, "start": 601.16, "text": "a"}, {"end": 601.72, "start": 601.4, "text": "trillion"}, {"end": 602.36, "start": 601.72, "text": "numbers"}, {"end": 602.96, "start": 602.36, "text": "and"}, {"end": 603.0, "start": 602.96, "text": "you"}, {"end": 603.16, "start": 603.0, "text": "wanted"}, {"end": 603.68, "start": 603.16, "text": "to"}, {"end": 604.2, "start": 603.68, "text": "sort"}, {"end": 604.32, "start": 604.2, "text": "them."}, {"end": 604.48, "start": 604.32, "text": "What"}, {"end": 604.84, "start": 604.48, "text": "kind"}, {"end": 605.04, "start": 604.84, "text": "of"}, {"end": 605.44, "start": 605.04, "text": "algorithm"}, {"end": 605.48, "start": 605.44, "text": "could"}, {"end": 605.6, "start": 605.48, "text": "you"}, {"end": 605.96, "start": 605.6, "text": "use"}, {"end": 607.2, "start": 605.96, "text": "for"}, {"end": 607.36, "start": 607.2, "text": "that?"}, {"end": 608.04, "start": 607.36, "text": "Trees"}, {"end": 608.12, "start": 608.04, "text": "are"}, {"end": 608.12, "start": 608.12, "text": "a"}, {"end": 608.64, "start": 608.12, "text": "wonderful"}, {"end": 609.12, "start": 608.64, "text": "data"}, {"end": 610.4, "start": 609.12, "text": "structure."}, {"end": 610.8, "start": 610.4, "text": "There's"}, {"end": 611.0, "start": 610.8, "text": "different"}, {"end": 611.68, "start": 611.0, "text": "varieties,"}, {"end": 612.32, "start": 611.68, "text": "the"}, {"end": 612.6, "start": 612.32, "text": "most"}, {"end": 612.96, "start": 612.6, "text": "common"}, {"end": 613.16, "start": 612.96, "text": "being"}, {"end": 613.52, "start": 613.16, "text": "binary"}, {"end": 614.76, "start": 613.52, "text": "trees."}, {"end": 615.24, "start": 614.76, "text": "And"}, {"end": 615.48, "start": 615.24, "text": "there's"}, {"end": 616.08, "start": 615.48, "text": "ways"}, {"end": 616.24, "start": 616.08, "text": "of"}, {"end": 616.72, "start": 616.24, "text": "doing"}, {"end": 616.88, "start": 616.72, "text": "all"}, {"end": 617.16, "start": 616.88, "text": "sorts"}, {"end": 617.2, "start": 617.16, "text": "of"}, {"end": 617.52, "start": 617.2, "text": "things"}, {"end": 618.2, "start": 617.52, "text": "like"}, {"end": 619.28, "start": 618.2, "text": "scheduling"}, {"end": 619.56, "start": 619.28, "text": "and"}, {"end": 620.56, "start": 619.56, "text": "sorting"}, {"end": 621.44, "start": 620.56, "text": "using"}, {"end": 621.84, "start": 621.44, "text": "various"}, {"end": 622.12, "start": 621.84, "text": "kinds"}, {"end": 622.12, "start": 622.12, "text": "of"}, {"end": 622.56, "start": 622.12, "text": "trees,"}, {"end": 622.88, "start": 622.56, "text": "including"}, {"end": 623.2, "start": 622.88, "text": "binary"}, {"end": 624.16, "start": 623.2, "text": "trees."}, {"end": 624.32, "start": 624.16, "text": "And"}, {"end": 624.6, "start": 624.32, "text": "we"}, {"end": 625.0, "start": 624.6, "text": "have"}, {"end": 625.2, "start": 625.0, "text": "a"}, {"end": 625.6, "start": 625.2, "text": "problem"}, {"end": 625.92, "start": 625.6, "text": "set"}, {"end": 626.4, "start": 625.92, "text": "on"}, {"end": 627.72, "start": 626.4, "text": "simulating"}, {"end": 629.44, "start": 627.72, "text": "a"}, {"end": 629.96, "start": 629.44, "text": "logic"}], "text": " Imagine if you had a trillion numbers and you wanted to sort them. What kind of algorithm could you use for that? Trees are a wonderful data structure. There's different varieties, the most common being binary trees. And there's ways of doing all sorts of things like scheduling and sorting using various kinds of trees, including binary trees. And we have a problem set on simulating a logic"}, {"chunks": [{"end": 631.4, "start": 630.0, "text": "network"}, {"end": 632.48, "start": 631.4, "text": "using"}, {"end": 632.6, "start": 632.48, "text": "a"}, {"end": 633.04, "start": 632.6, "text": "particular"}, {"end": 633.64, "start": 633.04, "text": "kind"}, {"end": 634.52, "start": 633.64, "text": "of"}, {"end": 634.88, "start": 634.52, "text": "sorting"}, {"end": 635.88, "start": 634.88, "text": "algorithm"}, {"end": 636.08, "start": 635.88, "text": "and"}, {"end": 636.4, "start": 636.08, "text": "a"}, {"end": 636.88, "start": 636.4, "text": "data"}, {"end": 638.24, "start": 636.88, "text": "structure."}, {"end": 638.68, "start": 638.24, "text": "That"}, {"end": 638.84, "start": 638.68, "text": "is"}, {"end": 639.2, "start": 638.84, "text": "going"}, {"end": 639.36, "start": 639.2, "text": "to"}, {"end": 639.48, "start": 639.36, "text": "be"}, {"end": 639.68, "start": 639.48, "text": "our"}, {"end": 641.16, "start": 639.68, "text": "second"}, {"end": 641.8, "start": 641.16, "text": "problem"}, {"end": 642.2, "start": 641.8, "text": "set."}, {"end": 642.44, "start": 642.2, "text": "And"}, {"end": 642.64, "start": 642.44, "text": "more"}, {"end": 643.0, "start": 642.64, "text": "quickly,"}, {"end": 644.0, "start": 643.0, "text": "we're"}, {"end": 644.16, "start": 644.0, "text": "going"}, {"end": 644.88, "start": 644.16, "text": "to"}, {"end": 645.32, "start": 644.88, "text": "have"}, {"end": 645.84, "start": 645.32, "text": "modules"}, {"end": 646.08, "start": 645.84, "text": "on"}, {"end": 647.04, "start": 646.08, "text": "hashing"}, {"end": 647.44, "start": 647.04, "text": "where"}, {"end": 647.6, "start": 647.44, "text": "we'll"}, {"end": 647.76, "start": 647.6, "text": "do"}, {"end": 648.08, "start": 647.76, "text": "things"}, {"end": 649.4, "start": 648.08, "text": "like"}, {"end": 649.96, "start": 649.4, "text": "genome"}, {"end": 651.24, "start": 649.96, "text": "comparison."}, {"end": 651.36, "start": 651.24, "text": "In"}, {"end": 651.68, "start": 651.36, "text": "past"}, {"end": 652.36, "start": 651.68, "text": "terms,"}, {"end": 653.04, "start": 652.36, "text": "we"}, {"end": 653.48, "start": 653.04, "text": "compared"}, {"end": 653.68, "start": 653.48, "text": "a"}, {"end": 654.32, "start": 653.68, "text": "human"}, {"end": 654.68, "start": 654.32, "text": "genome"}, {"end": 654.76, "start": 654.68, "text": "to"}, {"end": 654.88, "start": 654.76, "text": "a"}, {"end": 655.2, "start": 654.88, "text": "rat"}, {"end": 656.32, "start": 655.2, "text": "genome"}, {"end": 656.44, "start": 656.32, "text": "and"}, {"end": 656.88, "start": 656.44, "text": "discovered"}, {"end": 656.92, "start": 656.88, "text": "they"}, {"end": 657.28, "start": 656.92, "text": "were"}, {"end": 657.48, "start": 657.28, "text": "pretty"}, {"end": 658.56, "start": 657.48, "text": "similar."}, {"end": 659.32, "start": 658.56, "text": "99%"}, {"end": 659.52, "start": 659.32, "text": "of"}, {"end": 659.96, "start": 659.52, "text": "them."}], "text": " network using a particular kind of sorting algorithm and a data structure. That is going to be our second problem set. And more quickly, we're going to have modules on hashing where we'll do things like genome comparison. In past terms, we compared a human genome to a rat genome and discovered they were pretty similar. 99% of them."}, {"chunks": [{"end": 660.12, "start": 660.0, "text": "and"}, {"end": 660.28, "start": 660.12, "text": "similar,"}, {"end": 660.68, "start": 660.28, "text": "which"}, {"end": 660.68, "start": 660.68, "text": "is"}, {"end": 660.88, "start": 660.68, "text": "kind"}, {"end": 661.0, "start": 660.88, "text": "of"}, {"end": 661.72, "start": 661.0, "text": "amazing."}, {"end": 661.92, "start": 661.72, "text": "But"}, {"end": 662.36, "start": 661.92, "text": "again,"}, {"end": 662.6, "start": 662.36, "text": "these"}, {"end": 662.88, "start": 662.6, "text": "things"}, {"end": 663.08, "start": 662.88, "text": "are"}, {"end": 663.32, "start": 663.08, "text": "so"}, {"end": 664.32, "start": 663.32, "text": "large"}, {"end": 664.6, "start": 664.32, "text": "that"}, {"end": 664.72, "start": 664.6, "text": "you"}, {"end": 664.76, "start": 664.72, "text": "have"}, {"end": 664.92, "start": 664.76, "text": "to"}, {"end": 665.12, "start": 664.92, "text": "have"}, {"end": 666.2, "start": 665.12, "text": "efficiency"}, {"end": 666.44, "start": 666.2, "text": "in"}, {"end": 666.68, "start": 666.44, "text": "the"}, {"end": 667.04, "start": 666.68, "text": "comparison"}, {"end": 667.48, "start": 667.04, "text": "methods"}, {"end": 667.48, "start": 667.48, "text": "that"}, {"end": 667.56, "start": 667.48, "text": "you"}, {"end": 668.08, "start": 667.56, "text": "use."}, {"end": 668.48, "start": 668.08, "text": "And"}, {"end": 668.76, "start": 668.48, "text": "you'll"}, {"end": 669.08, "start": 668.76, "text": "find"}, {"end": 669.8, "start": 669.08, "text": "that"}, {"end": 670.24, "start": 669.8, "text": "if"}, {"end": 670.48, "start": 670.24, "text": "you"}, {"end": 670.8, "start": 670.48, "text": "don't"}, {"end": 670.84, "start": 670.8, "text": "get"}, {"end": 670.96, "start": 670.84, "text": "the"}, {"end": 671.4, "start": 670.96, "text": "complexity"}, {"end": 671.68, "start": 671.4, "text": "low"}, {"end": 672.24, "start": 671.68, "text": "enough,"}, {"end": 672.36, "start": 672.24, "text": "you"}, {"end": 672.56, "start": 672.36, "text": "just"}, {"end": 673.36, "start": 672.56, "text": "won't"}, {"end": 673.92, "start": 673.36, "text": "be"}, {"end": 674.52, "start": 673.92, "text": "able"}, {"end": 675.28, "start": 674.52, "text": "to"}, {"end": 675.48, "start": 675.28, "text": "complete."}, {"end": 675.68, "start": 675.48, "text": "Your"}, {"end": 676.12, "start": 675.68, "text": "program"}, {"end": 676.24, "start": 676.12, "text": "won't"}, {"end": 676.44, "start": 676.24, "text": "be"}, {"end": 676.56, "start": 676.44, "text": "able"}, {"end": 677.0, "start": 676.56, "text": "to"}, {"end": 677.28, "start": 677.0, "text": "finish"}, {"end": 678.24, "start": 677.28, "text": "running"}, {"end": 679.12, "start": 678.24, "text": "within"}, {"end": 679.36, "start": 679.12, "text": "the"}, {"end": 679.88, "start": 679.36, "text": "time"}, {"end": 680.0, "start": 679.88, "text": "that"}, {"end": 680.08, "start": 680.0, "text": "your"}, {"end": 680.32, "start": 680.08, "text": "problem"}, {"end": 680.48, "start": 680.32, "text": "set"}, {"end": 680.68, "start": 680.48, "text": "is"}, {"end": 680.88, "start": 680.68, "text": "due,"}, {"end": 681.0, "start": 680.88, "text": "which"}, {"end": 681.36, "start": 681.0, "text": "is"}, {"end": 681.72, "start": 681.36, "text": "a"}, {"end": 682.08, "start": 681.72, "text": "bit"}, {"end": 682.36, "start": 682.08, "text": "of"}, {"end": 682.68, "start": 682.36, "text": "a"}, {"end": 683.68, "start": 682.68, "text": "problem."}, {"end": 684.6, "start": 683.68, "text": "So"}, {"end": 684.88, "start": 684.6, "text": "that's"}, {"end": 685.2, "start": 684.88, "text": "something"}, {"end": 685.28, "start": 685.2, "text": "to"}, {"end": 685.36, "start": 685.28, "text": "keep"}, {"end": 685.52, "start": 685.36, "text": "in"}, {"end": 686.04, "start": 685.52, "text": "mind"}, {"end": 686.52, "start": 686.04, "text": "as"}, {"end": 687.0, "start": 686.52, "text": "you"}, {"end": 687.28, "start": 687.0, "text": "test"}, {"end": 687.44, "start": 687.28, "text": "your"}, {"end": 687.88, "start": 687.44, "text": "code."}, {"end": 688.28, "start": 687.88, "text": "The"}, {"end": 688.72, "start": 688.28, "text": "fact"}, {"end": 688.96, "start": 688.72, "text": "is"}, {"end": 689.44, "start": 688.96, "text": "that"}, {"end": 689.48, "start": 689.44, "text": "you"}, {"end": 689.76, "start": 689.48, "text": "will"}, {"end": 689.96, "start": 689.76, "text": "get"}], "text": " and similar, which is kind of amazing. But again, these things are so large that you have to have efficiency in the comparison methods that you use. And you'll find that if you don't get the complexity low enough, you just won't be able to complete. Your program won't be able to finish running within the time that your problem set is due, which is a bit of a problem. So that's something to keep in mind as you test your code. The fact is that you will get"}, {"chunks": [{"end": 690.36, "start": 690.0, "text": "Large"}, {"end": 690.88, "start": 690.36, "text": "inputs"}, {"end": 691.08, "start": 690.88, "text": "to"}, {"end": 692.2, "start": 691.08, "text": "run"}, {"end": 692.56, "start": 692.2, "text": "your"}, {"end": 693.12, "start": 692.56, "text": "code."}, {"end": 693.44, "start": 693.12, "text": "And"}, {"end": 693.48, "start": 693.44, "text": "you"}, {"end": 693.76, "start": 693.48, "text": "want"}, {"end": 693.88, "start": 693.76, "text": "to"}, {"end": 693.92, "start": 693.88, "text": "keep"}, {"end": 694.4, "start": 693.92, "text": "complexity"}, {"end": 694.56, "start": 694.4, "text": "in"}, {"end": 694.96, "start": 694.56, "text": "mind"}, {"end": 695.2, "start": 694.96, "text": "as"}, {"end": 695.84, "start": 695.2, "text": "you're"}, {"end": 696.28, "start": 695.84, "text": "coding"}, {"end": 696.28, "start": 696.28, "text": "and"}, {"end": 696.72, "start": 696.28, "text": "thinking"}, {"end": 697.56, "start": 696.72, "text": "about"}, {"end": 698.36, "start": 697.56, "text": "the"}, {"end": 699.32, "start": 698.36, "text": "pseudocode,"}, {"end": 699.64, "start": 699.32, "text": "if"}, {"end": 699.8, "start": 699.64, "text": "you"}, {"end": 700.28, "start": 699.8, "text": "will,"}, {"end": 700.52, "start": 700.28, "text": "of"}, {"end": 700.84, "start": 700.52, "text": "your"}, {"end": 701.08, "start": 700.84, "text": "algorithm"}, {"end": 701.48, "start": 701.08, "text": "itself."}, {"end": 702.0, "start": 701.48, "text": "We"}, {"end": 702.32, "start": 702.0, "text": "will"}, {"end": 703.56, "start": 702.32, "text": "talk"}, {"end": 704.32, "start": 703.56, "text": "about"}, {"end": 705.44, "start": 704.32, "text": "numerics."}, {"end": 705.72, "start": 705.44, "text": "A"}, {"end": 706.24, "start": 705.72, "text": "lot"}, {"end": 707.12, "start": 706.24, "text": "of"}, {"end": 707.32, "start": 707.12, "text": "the"}, {"end": 708.12, "start": 707.32, "text": "time,"}, {"end": 708.24, "start": 708.12, "text": "we"}, {"end": 708.56, "start": 708.24, "text": "talk"}, {"end": 709.24, "start": 708.56, "text": "about"}, {"end": 709.6, "start": 709.24, "text": "such"}, {"end": 709.96, "start": 709.6, "text": "large"}, {"end": 710.8, "start": 709.96, "text": "numbers"}, {"end": 711.0, "start": 710.8, "text": "that"}, {"end": 711.44, "start": 711.0, "text": "32"}, {"end": 711.92, "start": 711.44, "text": "bits"}, {"end": 712.16, "start": 711.92, "text": "isn't"}, {"end": 713.36, "start": 712.16, "text": "enough,"}, {"end": 713.72, "start": 713.36, "text": "or"}, {"end": 714.48, "start": 713.72, "text": "64"}, {"end": 714.68, "start": 714.48, "text": "bits"}, {"end": 715.28, "start": 714.68, "text": "isn't"}, {"end": 715.52, "start": 715.28, "text": "enough"}, {"end": 715.76, "start": 715.52, "text": "to"}, {"end": 716.04, "start": 715.76, "text": "represent"}, {"end": 716.24, "start": 716.04, "text": "these"}, {"end": 716.96, "start": 716.24, "text": "numbers."}, {"end": 717.12, "start": 716.96, "text": "These"}, {"end": 717.44, "start": 717.12, "text": "numbers"}, {"end": 717.64, "start": 717.44, "text": "have"}, {"end": 718.16, "start": 717.64, "text": "thousands"}, {"end": 718.16, "start": 718.16, "text": "of"}, {"end": 718.84, "start": 718.16, "text": "bits."}, {"end": 718.92, "start": 718.84, "text": "A"}, {"end": 718.92, "start": 718.92, "text": "good"}, {"end": 719.48, "start": 718.92, "text": "example"}, {"end": 719.6, "start": 719.48, "text": "is"}, {"end": 719.96, "start": 719.6, "text": "RSA."}], "text": " Large inputs to run your code. And you want to keep complexity in mind as you're coding and thinking about the pseudocode, if you will, of your algorithm itself. We will talk about numerics. A lot of the time, we talk about such large numbers that 32 bits isn't enough, or 64 bits isn't enough to represent these numbers. These numbers have thousands of bits. A good example is RSA."}, {"chunks": [{"end": 720.68, "start": 720.0, "text": "encryption"}, {"end": 721.12, "start": 720.68, "text": "that"}, {"end": 721.36, "start": 721.12, "text": "is"}, {"end": 722.8, "start": 721.36, "text": "used"}, {"end": 723.32, "start": 722.8, "text": "in"}, {"end": 724.08, "start": 723.32, "text": "SSL,"}, {"end": 724.2, "start": 724.08, "text": "for"}, {"end": 724.52, "start": 724.2, "text": "example."}, {"end": 725.12, "start": 724.52, "text": "And"}, {"end": 725.84, "start": 725.12, "text": "when"}, {"end": 726.72, "start": 725.84, "text": "you"}, {"end": 727.16, "start": 726.72, "text": "go"}, {"end": 727.36, "start": 727.16, "text": "use"}, {"end": 728.36, "start": 727.36, "text": "HTTPS"}, {"end": 728.36, "start": 728.36, "text": "on"}, {"end": 729.52, "start": 728.36, "text": "websites,"}, {"end": 730.4, "start": 729.52, "text": "RSA"}, {"end": 730.6, "start": 730.4, "text": "is"}, {"end": 731.36, "start": 730.6, "text": "used"}, {"end": 731.44, "start": 731.36, "text": "at"}, {"end": 731.64, "start": 731.44, "text": "the"}, {"end": 731.96, "start": 731.64, "text": "back"}, {"end": 732.68, "start": 731.96, "text": "end."}, {"end": 732.96, "start": 732.68, "text": "And"}, {"end": 733.32, "start": 732.96, "text": "typically,"}, {"end": 733.64, "start": 733.32, "text": "you"}, {"end": 734.04, "start": 733.64, "text": "work"}, {"end": 734.28, "start": 734.04, "text": "with"}, {"end": 734.92, "start": 734.28, "text": "prime"}, {"end": 735.32, "start": 734.92, "text": "numbers"}, {"end": 735.56, "start": 735.32, "text": "that"}, {"end": 735.6, "start": 735.56, "text": "are"}, {"end": 736.12, "start": 735.6, "text": "thousands"}, {"end": 736.2, "start": 736.12, "text": "of"}, {"end": 736.92, "start": 736.2, "text": "bits"}, {"end": 737.44, "start": 736.92, "text": "long"}, {"end": 737.52, "start": 737.44, "text": "in"}, {"end": 738.48, "start": 737.52, "text": "RSA."}, {"end": 739.24, "start": 738.48, "text": "So"}, {"end": 739.76, "start": 739.24, "text": "how"}, {"end": 739.8, "start": 739.76, "text": "do"}, {"end": 739.8, "start": 739.8, "text": "you"}, {"end": 739.8, "start": 739.8, "text": "handle"}, {"end": 739.8, "start": 739.8, "text": "that?"}, {"end": 739.8, "start": 739.8, "text": "How"}, {"end": 740.04, "start": 739.8, "text": "does"}, {"end": 740.08, "start": 740.04, "text": "Python"}, {"end": 740.24, "start": 740.08, "text": "handle"}, {"end": 740.48, "start": 740.24, "text": "that?"}, {"end": 741.04, "start": 740.48, "text": "How"}, {"end": 741.04, "start": 741.04, "text": "do"}, {"end": 741.2, "start": 741.04, "text": "you"}, {"end": 741.72, "start": 741.2, "text": "write"}, {"end": 742.6, "start": 741.72, "text": "algorithms"}, {"end": 742.72, "start": 742.6, "text": "that"}, {"end": 742.92, "start": 742.72, "text": "can"}, {"end": 743.16, "start": 742.92, "text": "deal"}, {"end": 743.96, "start": 743.16, "text": "with"}, {"end": 744.2, "start": 743.96, "text": "what"}, {"end": 744.36, "start": 744.2, "text": "are"}, {"end": 744.52, "start": 744.36, "text": "called"}, {"end": 744.8, "start": 744.52, "text": "infinite"}, {"end": 745.32, "start": 744.8, "text": "precision"}, {"end": 746.2, "start": 745.32, "text": "numbers?"}, {"end": 746.52, "start": 746.2, "text": "So"}, {"end": 746.6, "start": 746.52, "text": "we"}, {"end": 746.72, "start": 746.6, "text": "have"}, {"end": 746.96, "start": 746.72, "text": "a"}, {"end": 747.32, "start": 746.96, "text": "module"}, {"end": 747.44, "start": 747.32, "text": "on"}, {"end": 748.68, "start": 747.44, "text": "numerics"}, {"end": 748.68, "start": 748.68, "text": "in"}, {"end": 748.72, "start": 748.68, "text": "the"}, {"end": 748.84, "start": 748.72, "text": "middle"}, {"end": 749.12, "start": 748.84, "text": "of"}, {"end": 749.16, "start": 749.12, "text": "the"}, {"end": 749.44, "start": 749.16, "text": "term"}, {"end": 749.96, "start": 749.44, "text": "that"}], "text": " encryption that is used in SSL, for example. And when you go use HTTPS on websites, RSA is used at the back end. And typically, you work with prime numbers that are thousands of bits long in RSA. So how do you handle that? How does Python handle that? How do you write algorithms that can deal with what are called infinite precision numbers? So we have a module on numerics in the middle of the term that"}, {"chunks": [{"end": 750.76, "start": 750.0, "text": "talks"}, {"end": 751.12, "start": 750.76, "text": "about"}, {"end": 751.84, "start": 751.12, "text": "that."}, {"end": 753.28, "start": 751.84, "text": "Graphs,"}, {"end": 753.48, "start": 753.28, "text": "really"}, {"end": 753.52, "start": 753.48, "text": "a"}, {"end": 754.76, "start": 753.52, "text": "fundamental"}, {"end": 755.16, "start": 754.76, "text": "data"}, {"end": 755.6, "start": 755.16, "text": "structure"}, {"end": 755.72, "start": 755.6, "text": "in"}, {"end": 755.96, "start": 755.72, "text": "all"}, {"end": 756.0, "start": 755.96, "text": "of"}, {"end": 756.4, "start": 756.0, "text": "computer"}, {"end": 757.12, "start": 756.4, "text": "science."}, {"end": 757.24, "start": 757.12, "text": "You"}, {"end": 757.48, "start": 757.24, "text": "might"}, {"end": 758.08, "start": 757.48, "text": "have"}, {"end": 758.72, "start": 758.08, "text": "heard"}, {"end": 759.68, "start": 758.72, "text": "of"}, {"end": 760.08, "start": 759.68, "text": "the"}, {"end": 760.48, "start": 760.08, "text": "famous"}, {"end": 760.96, "start": 760.48, "text": "Rubik's"}, {"end": 761.96, "start": 760.96, "text": "cube"}, {"end": 762.56, "start": 761.96, "text": "assignment"}, {"end": 762.72, "start": 762.56, "text": "from"}, {"end": 764.04, "start": 762.72, "text": "006,"}, {"end": 764.28, "start": 764.04, "text": "a"}, {"end": 764.6, "start": 764.28, "text": "2"}, {"end": 764.8, "start": 764.6, "text": "by"}, {"end": 765.0, "start": 764.8, "text": "2"}, {"end": 765.12, "start": 765.0, "text": "by"}, {"end": 765.44, "start": 765.12, "text": "2"}, {"end": 765.68, "start": 765.44, "text": "Rubik's"}, {"end": 766.64, "start": 765.68, "text": "cube."}, {"end": 767.24, "start": 766.64, "text": "What's"}, {"end": 767.44, "start": 767.24, "text": "the"}, {"end": 767.84, "start": 767.44, "text": "minimum"}, {"end": 768.0, "start": 767.84, "text": "number"}, {"end": 768.16, "start": 768.0, "text": "of"}, {"end": 768.64, "start": 768.16, "text": "moves"}, {"end": 769.44, "start": 768.64, "text": "necessary"}, {"end": 770.24, "start": 769.44, "text": "to"}, {"end": 770.48, "start": 770.24, "text": "go"}, {"end": 770.84, "start": 770.48, "text": "from"}, {"end": 770.84, "start": 770.84, "text": "a"}, {"end": 771.32, "start": 770.84, "text": "given"}, {"end": 771.8, "start": 771.32, "text": "starting"}, {"end": 772.76, "start": 771.8, "text": "configuration"}, {"end": 773.48, "start": 772.76, "text": "to"}, {"end": 773.56, "start": 773.48, "text": "the"}, {"end": 774.24, "start": 773.56, "text": "final"}, {"end": 774.32, "start": 774.24, "text": "end"}, {"end": 774.84, "start": 774.32, "text": "configuration"}, {"end": 775.16, "start": 774.84, "text": "where"}, {"end": 775.2, "start": 775.16, "text": "all"}, {"end": 775.2, "start": 775.2, "text": "of"}, {"end": 775.32, "start": 775.2, "text": "the"}, {"end": 775.96, "start": 775.32, "text": "faces,"}, {"end": 776.12, "start": 775.96, "text": "each"}, {"end": 776.64, "start": 776.12, "text": "of"}, {"end": 776.76, "start": 776.64, "text": "the"}, {"end": 777.04, "start": 776.76, "text": "faces"}, {"end": 777.44, "start": 777.04, "text": "has"}, {"end": 777.76, "start": 777.44, "text": "uniform"}, {"end": 778.76, "start": 777.76, "text": "color?"}, {"end": 779.04, "start": 778.76, "text": "And"}, {"end": 779.52, "start": 779.04, "text": "that"}, {"end": 779.76, "start": 779.52, "text": "can"}, {"end": 779.96, "start": 779.76, "text": "be"}], "text": " talks about that. Graphs, really a fundamental data structure in all of computer science. You might have heard of the famous Rubik's cube assignment from 006, a 2 by 2 by 2 Rubik's cube. What's the minimum number of moves necessary to go from a given starting configuration to the final end configuration where all of the faces, each of the faces has uniform color? And that can be"}, {"chunks": [{"end": 780.2, "start": 780.0, "text": "Post"}, {"end": 780.32, "start": 780.2, "text": "is"}, {"end": 780.4, "start": 780.32, "text": "a"}, {"end": 780.68, "start": 780.4, "text": "graph"}, {"end": 781.8, "start": 780.68, "text": "problem."}, {"end": 782.08, "start": 781.8, "text": "We'll"}, {"end": 782.4, "start": 782.08, "text": "probably"}, {"end": 782.48, "start": 782.4, "text": "do"}, {"end": 782.68, "start": 782.48, "text": "that"}, {"end": 783.44, "start": 782.68, "text": "one"}, {"end": 783.68, "start": 783.44, "text": "this"}, {"end": 784.16, "start": 783.68, "text": "term."}, {"end": 784.28, "start": 784.16, "text": "In"}, {"end": 784.64, "start": 784.28, "text": "previous"}, {"end": 784.88, "start": 784.64, "text": "terms,"}, {"end": 785.0, "start": 784.88, "text": "we've"}, {"end": 785.2, "start": 785.0, "text": "done"}, {"end": 785.36, "start": 785.2, "text": "other"}, {"end": 785.72, "start": 785.36, "text": "things"}, {"end": 785.88, "start": 785.72, "text": "like"}, {"end": 786.0, "start": 785.88, "text": "the"}, {"end": 786.4, "start": 786.0, "text": "15"}, {"end": 787.28, "start": 786.4, "text": "puzzle."}, {"end": 787.44, "start": 787.28, "text": "And"}, {"end": 787.84, "start": 787.44, "text": "so"}, {"end": 788.48, "start": 787.84, "text": "some"}, {"end": 788.72, "start": 788.48, "text": "of"}, {"end": 789.36, "start": 788.72, "text": "these"}, {"end": 789.72, "start": 789.36, "text": "are"}, {"end": 790.16, "start": 789.72, "text": "tentative."}, {"end": 790.36, "start": 790.16, "text": "We"}, {"end": 790.68, "start": 790.36, "text": "definitely"}, {"end": 790.96, "start": 790.68, "text": "know"}, {"end": 790.96, "start": 790.96, "text": "what"}, {"end": 791.0, "start": 790.96, "text": "the"}, {"end": 791.2, "start": 791.0, "text": "first"}, {"end": 791.48, "start": 791.2, "text": "problem"}, {"end": 791.92, "start": 791.48, "text": "set"}, {"end": 792.48, "start": 791.92, "text": "is"}, {"end": 792.72, "start": 792.48, "text": "like."}, {"end": 793.0, "start": 792.72, "text": "But"}, {"end": 793.28, "start": 793.0, "text": "the"}, {"end": 793.6, "start": 793.28, "text": "rest"}, {"end": 793.72, "start": 793.6, "text": "of"}, {"end": 793.76, "start": 793.72, "text": "them"}, {"end": 793.84, "start": 793.76, "text": "are,"}, {"end": 794.2, "start": 793.84, "text": "at"}, {"end": 794.44, "start": 794.2, "text": "this"}, {"end": 794.72, "start": 794.44, "text": "moment,"}, {"end": 795.84, "start": 794.72, "text": "tentative."}, {"end": 796.32, "start": 795.84, "text": "And"}, {"end": 796.68, "start": 796.32, "text": "to"}, {"end": 797.2, "start": 796.68, "text": "finish"}, {"end": 798.4, "start": 797.2, "text": "up,"}, {"end": 799.04, "start": 798.4, "text": "shortest"}, {"end": 800.28, "start": 799.04, "text": "paths."}, {"end": 801.12, "start": 800.28, "text": "Again,"}, {"end": 801.24, "start": 801.12, "text": "in"}, {"end": 801.68, "start": 801.24, "text": "terms"}, {"end": 802.32, "start": 801.68, "text": "passed,"}, {"end": 802.88, "start": 802.32, "text": "we've"}, {"end": 803.52, "start": 802.88, "text": "asked"}, {"end": 804.52, "start": 803.52, "text": "to"}, {"end": 804.96, "start": 804.52, "text": "write"}, {"end": 805.92, "start": 804.96, "text": "code"}, {"end": 806.24, "start": 805.92, "text": "using"}, {"end": 806.32, "start": 806.24, "text": "a"}, {"end": 806.52, "start": 806.32, "text": "particular"}, {"end": 807.16, "start": 806.52, "text": "algorithm"}, {"end": 807.28, "start": 807.16, "text": "that"}, {"end": 807.56, "start": 807.28, "text": "finds"}, {"end": 807.64, "start": 807.56, "text": "the"}, {"end": 807.96, "start": 807.64, "text": "shortest"}, {"end": 808.24, "start": 807.96, "text": "path"}, {"end": 808.4, "start": 808.24, "text": "from"}, {"end": 808.84, "start": 808.4, "text": "Caltech"}, {"end": 808.88, "start": 808.84, "text": "to"}, {"end": 809.96, "start": 808.88, "text": "MIT."}], "text": " Post is a graph problem. We'll probably do that one this term. In previous terms, we've done other things like the 15 puzzle. And so some of these are tentative. We definitely know what the first problem set is like. But the rest of them are, at this moment, tentative. And to finish up, shortest paths. Again, in terms passed, we've asked to write code using a particular algorithm that finds the shortest path from Caltech to MIT."}, {"chunks": [{"end": 810.24, "start": 810.0, "text": "This"}, {"end": 811.08, "start": 810.24, "text": "time,"}, {"end": 811.36, "start": 811.08, "text": "we"}, {"end": 811.8, "start": 811.36, "text": "may"}, {"end": 811.8, "start": 811.8, "text": "do"}, {"end": 812.0, "start": 811.8, "text": "things"}, {"end": 812.08, "start": 812.0, "text": "a"}, {"end": 812.4, "start": 812.08, "text": "little"}, {"end": 812.48, "start": 812.4, "text": "bit"}, {"end": 813.16, "start": 812.48, "text": "differently."}, {"end": 813.68, "start": 813.16, "text": "We're"}, {"end": 814.44, "start": 813.68, "text": "thinking"}, {"end": 814.56, "start": 814.44, "text": "maybe"}, {"end": 814.76, "start": 814.56, "text": "we'll"}, {"end": 814.96, "start": 814.76, "text": "give"}, {"end": 815.12, "start": 814.96, "text": "you"}, {"end": 815.4, "start": 815.12, "text": "a"}, {"end": 815.64, "start": 815.4, "text": "street"}, {"end": 816.12, "start": 815.64, "text": "map"}, {"end": 817.12, "start": 816.12, "text": "of"}, {"end": 817.64, "start": 817.12, "text": "Boston"}, {"end": 818.2, "start": 817.64, "text": "and"}, {"end": 818.8, "start": 818.2, "text": "go"}, {"end": 819.0, "start": 818.8, "text": "figure"}, {"end": 819.24, "start": 819.0, "text": "out"}, {"end": 819.68, "start": 819.24, "text": "if"}, {"end": 820.08, "start": 819.68, "text": "Paul"}, {"end": 821.04, "start": 820.08, "text": "Revere"}, {"end": 821.32, "start": 821.04, "text": "used"}, {"end": 821.4, "start": 821.32, "text": "a"}, {"end": 821.76, "start": 821.4, "text": "shortest"}, {"end": 822.12, "start": 821.76, "text": "path"}, {"end": 822.4, "start": 822.12, "text": "to"}, {"end": 822.48, "start": 822.4, "text": "get"}, {"end": 822.76, "start": 822.48, "text": "to"}, {"end": 822.92, "start": 822.76, "text": "where"}, {"end": 822.96, "start": 822.92, "text": "he"}, {"end": 823.4, "start": 822.96, "text": "was"}, {"end": 824.08, "start": 823.4, "text": "going,"}, {"end": 824.2, "start": 824.08, "text": "or"}, {"end": 824.44, "start": 824.2, "text": "things"}, {"end": 824.6, "start": 824.44, "text": "like"}, {"end": 825.16, "start": 824.6, "text": "that."}, {"end": 825.24, "start": 825.16, "text": "We'll"}, {"end": 825.76, "start": 825.24, "text": "try"}, {"end": 826.84, "start": 825.76, "text": "and"}, {"end": 827.32, "start": 826.84, "text": "make"}, {"end": 827.32, "start": 827.32, "text": "it"}, {"end": 827.56, "start": 827.32, "text": "fun."}, {"end": 827.96, "start": 827.56, "text": "Dynamic"}, {"end": 829.52, "start": 827.96, "text": "programming"}, {"end": 830.4, "start": 829.52, "text": "is"}, {"end": 831.44, "start": 830.4, "text": "an"}, {"end": 833.0, "start": 831.44, "text": "important"}, {"end": 833.92, "start": 833.0, "text": "algorithm"}, {"end": 834.32, "start": 833.92, "text": "design"}, {"end": 834.88, "start": 834.32, "text": "technique"}, {"end": 835.52, "start": 834.88, "text": "that's"}, {"end": 835.88, "start": 835.52, "text": "used"}, {"end": 837.04, "start": 835.88, "text": "in"}, {"end": 837.32, "start": 837.04, "text": "many,"}, {"end": 837.72, "start": 837.32, "text": "many"}, {"end": 839.96, "start": 837.72, "text": "problems."}], "text": " This time, we may do things a little bit differently. We're thinking maybe we'll give you a street map of Boston and go figure out if Paul Revere used a shortest path to get to where he was going, or things like that. We'll try and make it fun. Dynamic programming is an important algorithm design technique that's used in many, many problems."}, {"chunks": [{"end": 840.24, "start": 840.0, "text": "And"}, {"end": 840.32, "start": 840.24, "text": "it"}, {"end": 840.64, "start": 840.32, "text": "can"}, {"end": 841.2, "start": 840.64, "text": "be"}, {"end": 842.0, "start": 841.2, "text": "used"}, {"end": 842.12, "start": 842.0, "text": "to"}, {"end": 842.84, "start": 842.12, "text": "do"}, {"end": 843.2, "start": 842.84, "text": "a"}, {"end": 843.72, "start": 843.2, "text": "variety"}, {"end": 843.76, "start": 843.72, "text": "of"}, {"end": 844.08, "start": 843.76, "text": "things,"}, {"end": 844.48, "start": 844.08, "text": "including"}, {"end": 844.68, "start": 844.48, "text": "image"}, {"end": 845.32, "start": 844.68, "text": "compression."}, {"end": 846.12, "start": 845.32, "text": "How"}, {"end": 846.56, "start": 846.12, "text": "do"}, {"end": 846.92, "start": 846.56, "text": "you"}, {"end": 847.32, "start": 846.92, "text": "compress"}, {"end": 847.52, "start": 847.32, "text": "an"}, {"end": 848.32, "start": 847.52, "text": "image"}, {"end": 848.96, "start": 848.32, "text": "so"}, {"end": 849.12, "start": 848.96, "text": "the"}, {"end": 849.48, "start": 849.12, "text": "number"}, {"end": 849.56, "start": 849.48, "text": "of"}, {"end": 850.04, "start": 849.56, "text": "pixels"}, {"end": 851.28, "start": 850.04, "text": "reduces,"}, {"end": 851.52, "start": 851.28, "text": "but"}, {"end": 851.68, "start": 851.52, "text": "it"}, {"end": 851.92, "start": 851.68, "text": "still"}, {"end": 852.36, "start": 851.92, "text": "looks"}, {"end": 852.48, "start": 852.36, "text": "like"}, {"end": 852.72, "start": 852.48, "text": "the"}, {"end": 852.88, "start": 852.72, "text": "image"}, {"end": 853.48, "start": 852.88, "text": "that"}, {"end": 853.6, "start": 853.48, "text": "you"}, {"end": 854.04, "start": 853.6, "text": "started"}, {"end": 854.08, "start": 854.04, "text": "out"}, {"end": 854.24, "start": 854.08, "text": "with"}, {"end": 854.4, "start": 854.24, "text": "that"}, {"end": 854.64, "start": 854.4, "text": "had"}, {"end": 854.84, "start": 854.64, "text": "many"}, {"end": 855.04, "start": 854.84, "text": "more"}, {"end": 856.0, "start": 855.04, "text": "pixels."}, {"end": 856.28, "start": 856.0, "text": "So"}, {"end": 856.36, "start": 856.28, "text": "you"}, {"end": 856.4, "start": 856.36, "text": "could"}, {"end": 856.64, "start": 856.4, "text": "use"}, {"end": 857.0, "start": 856.64, "text": "dynamic"}, {"end": 857.4, "start": 857.0, "text": "programming"}, {"end": 858.32, "start": 857.4, "text": "for"}, {"end": 858.84, "start": 858.32, "text": "that."}, {"end": 858.92, "start": 858.84, "text": "And"}, {"end": 859.96, "start": 858.92, "text": "finally,"}, {"end": 860.64, "start": 859.96, "text": "advanced"}, {"end": 861.04, "start": 860.64, "text": "topics,"}, {"end": 861.6, "start": 861.04, "text": "complexity"}, {"end": 862.88, "start": 861.6, "text": "theory,"}, {"end": 863.44, "start": 862.88, "text": "research,"}, {"end": 863.72, "start": 863.44, "text": "and"}, {"end": 864.36, "start": 863.72, "text": "algorithms."}, {"end": 865.44, "start": 864.36, "text": "Hopefully"}, {"end": 865.6, "start": 865.44, "text": "by"}, {"end": 865.84, "start": 865.6, "text": "this"}, {"end": 866.32, "start": 865.84, "text": "time"}, {"end": 866.32, "start": 866.32, "text": "in"}, {"end": 866.88, "start": 866.32, "text": "the"}, {"end": 867.52, "start": 866.88, "text": "course,"}, {"end": 867.64, "start": 867.52, "text": "you"}, {"end": 868.12, "start": 867.64, "text": "would"}, {"end": 868.6, "start": 868.12, "text": "have"}, {"end": 868.8, "start": 868.6, "text": "been"}, {"end": 869.28, "start": 868.8, "text": "sold"}, {"end": 869.36, "start": 869.28, "text": "on"}, {"end": 869.96, "start": 869.36, "text": "algorithms"}], "text": " And it can be used to do a variety of things, including image compression. How do you compress an image so the number of pixels reduces, but it still looks like the image that you started out with that had many more pixels. So you could use dynamic programming for that. And finally, advanced topics, complexity theory, research, and algorithms. Hopefully by this time in the course, you would have been sold on algorithms"}, {"chunks": [{"end": 870.0, "start": 870.0, "text": "And"}, {"end": 870.08, "start": 870.0, "text": "most,"}, {"end": 870.24, "start": 870.08, "text": "if"}, {"end": 870.36, "start": 870.24, "text": "not"}, {"end": 870.72, "start": 870.36, "text": "all,"}, {"end": 871.08, "start": 870.72, "text": "of"}, {"end": 871.52, "start": 871.08, "text": "you"}, {"end": 871.92, "start": 871.52, "text": "would"}, {"end": 872.24, "start": 871.92, "text": "want"}, {"end": 872.72, "start": 872.24, "text": "to"}, {"end": 873.0, "start": 872.72, "text": "pursue"}, {"end": 873.2, "start": 873.0, "text": "a"}, {"end": 873.64, "start": 873.2, "text": "career"}, {"end": 873.72, "start": 873.64, "text": "in"}, {"end": 874.56, "start": 873.72, "text": "algorithms."}, {"end": 874.84, "start": 874.56, "text": "And"}, {"end": 875.32, "start": 874.84, "text": "we'll"}, {"end": 875.36, "start": 875.32, "text": "give"}, {"end": 875.4, "start": 875.36, "text": "you"}, {"end": 875.76, "start": 875.4, "text": "a"}, {"end": 876.12, "start": 875.76, "text": "sense"}, {"end": 876.32, "start": 876.12, "text": "of"}, {"end": 876.92, "start": 876.32, "text": "what"}, {"end": 877.32, "start": 876.92, "text": "else"}, {"end": 877.32, "start": 877.32, "text": "is"}, {"end": 877.6, "start": 877.32, "text": "there."}, {"end": 877.76, "start": 877.6, "text": "We're"}, {"end": 877.92, "start": 877.76, "text": "just"}, {"end": 878.32, "start": 877.92, "text": "scratching"}, {"end": 878.64, "start": 878.32, "text": "the"}, {"end": 879.32, "start": 878.64, "text": "surface"}, {"end": 879.44, "start": 879.32, "text": "in"}, {"end": 879.76, "start": 879.44, "text": "this"}, {"end": 880.28, "start": 879.76, "text": "class."}, {"end": 880.48, "start": 880.28, "text": "And"}, {"end": 880.88, "start": 880.48, "text": "there's"}, {"end": 881.08, "start": 880.88, "text": "many,"}, {"end": 881.28, "start": 881.08, "text": "many"}, {"end": 881.68, "start": 881.28, "text": "classes"}, {"end": 881.88, "start": 881.68, "text": "that"}, {"end": 881.92, "start": 881.88, "text": "you"}, {"end": 882.04, "start": 881.92, "text": "can"}, {"end": 882.44, "start": 882.04, "text": "possibly"}, {"end": 882.72, "start": 882.44, "text": "take"}, {"end": 882.96, "start": 882.72, "text": "if"}, {"end": 883.2, "start": 882.96, "text": "you"}, {"end": 883.6, "start": 883.2, "text": "want"}, {"end": 883.92, "start": 883.6, "text": "to"}, {"end": 884.04, "start": 883.92, "text": "continue"}, {"end": 884.24, "start": 884.04, "text": "to"}, {"end": 885.16, "start": 884.24, "text": "learn"}, {"end": 885.44, "start": 885.16, "text": "about"}, {"end": 886.72, "start": 885.44, "text": "algorithms"}, {"end": 887.48, "start": 886.72, "text": "or"}, {"end": 887.8, "start": 887.48, "text": "to"}, {"end": 888.24, "start": 887.8, "text": "pursue"}, {"end": 888.24, "start": 888.24, "text": "a"}, {"end": 888.52, "start": 888.24, "text": "career"}, {"end": 888.56, "start": 888.52, "text": "in"}, {"end": 888.76, "start": 888.56, "text": "algorithms."}, {"end": 888.88, "start": 888.76, "text": "All"}, {"end": 889.72, "start": 888.88, "text": "right?"}, {"end": 891.56, "start": 889.72, "text": "So"}, {"end": 892.0, "start": 891.56, "text": "that's"}, {"end": 892.36, "start": 892.0, "text": "the"}, {"end": 893.12, "start": 892.36, "text": "story"}, {"end": 893.36, "start": 893.12, "text": "of"}, {"end": 893.44, "start": 893.36, "text": "the"}, {"end": 893.92, "start": 893.44, "text": "class,"}, {"end": 893.92, "start": 893.92, "text": "of"}, {"end": 893.96, "start": 893.92, "text": "the"}, {"end": 894.52, "start": 893.96, "text": "synopsis"}, {"end": 894.52, "start": 894.52, "text": "of"}, {"end": 894.72, "start": 894.52, "text": "the"}, {"end": 895.84, "start": 894.72, "text": "class."}, {"end": 896.48, "start": 895.84, "text": "And"}, {"end": 897.08, "start": 896.48, "text": "I"}, {"end": 897.68, "start": 897.08, "text": "encourage"}, {"end": 898.04, "start": 897.68, "text": "you"}, {"end": 898.32, "start": 898.04, "text": "to"}, {"end": 898.8, "start": 898.32, "text": "go"}, {"end": 899.96, "start": 898.8, "text": "spend"}], "text": " And most, if not all, of you would want to pursue a career in algorithms. And we'll give you a sense of what else is there. We're just scratching the surface in this class. And there's many, many classes that you can possibly take if you want to continue to learn about algorithms or to pursue a career in algorithms. All right? So that's the story of the class, of the synopsis of the class. And I encourage you to go spend"}, {"chunks": [{"end": 900.28, "start": 900.0, "text": "A"}, {"end": 900.52, "start": 900.28, "text": "few"}, {"end": 900.92, "start": 900.52, "text": "minutes"}, {"end": 900.96, "start": 900.92, "text": "on"}, {"end": 901.04, "start": 900.96, "text": "the"}, {"end": 901.92, "start": 901.04, "text": "website."}, {"end": 902.08, "start": 901.92, "text": "In"}, {"end": 902.72, "start": 902.08, "text": "particular,"}, {"end": 903.48, "start": 902.72, "text": "please"}, {"end": 903.72, "start": 903.48, "text": "read"}, {"end": 903.88, "start": 903.72, "text": "the"}, {"end": 904.44, "start": 903.88, "text": "collaboration"}, {"end": 905.0, "start": 904.44, "text": "policy"}, {"end": 905.36, "start": 905.0, "text": "and"}, {"end": 905.48, "start": 905.36, "text": "get"}, {"end": 905.84, "start": 905.48, "text": "a"}, {"end": 906.28, "start": 905.84, "text": "sense"}, {"end": 906.32, "start": 906.28, "text": "of"}, {"end": 906.8, "start": 906.32, "text": "what"}, {"end": 907.04, "start": 906.8, "text": "is"}, {"end": 908.2, "start": 907.04, "text": "expected"}, {"end": 908.4, "start": 908.2, "text": "of"}, {"end": 908.4, "start": 908.4, "text": "you,"}, {"end": 908.72, "start": 908.4, "text": "what"}, {"end": 909.76, "start": 908.72, "text": "the"}, {"end": 910.16, "start": 909.76, "text": "rules"}, {"end": 910.52, "start": 910.16, "text": "are"}, {"end": 910.68, "start": 910.52, "text": "in"}, {"end": 911.04, "start": 910.68, "text": "terms"}, {"end": 911.8, "start": 911.04, "text": "of"}, {"end": 912.0, "start": 911.8, "text": "doing"}, {"end": 912.32, "start": 912.0, "text": "the"}, {"end": 912.64, "start": 912.32, "text": "problem"}, {"end": 913.6, "start": 912.64, "text": "sets,"}, {"end": 914.0, "start": 913.6, "text": "and"}, {"end": 915.28, "start": 914.0, "text": "the"}, {"end": 915.92, "start": 915.28, "text": "course"}, {"end": 916.12, "start": 915.92, "text": "grading"}, {"end": 916.8, "start": 916.12, "text": "breakdown"}, {"end": 917.12, "start": 916.8, "text": "and"}, {"end": 917.32, "start": 917.12, "text": "the"}, {"end": 917.56, "start": 917.32, "text": "grading"}, {"end": 918.48, "start": 917.56, "text": "policies"}, {"end": 918.6, "start": 918.48, "text": "are"}, {"end": 918.76, "start": 918.6, "text": "all"}, {"end": 919.12, "start": 918.76, "text": "listed"}, {"end": 919.12, "start": 919.12, "text": "on"}, {"end": 919.12, "start": 919.12, "text": "the"}, {"end": 919.52, "start": 919.12, "text": "website"}, {"end": 919.68, "start": 919.52, "text": "as"}, {"end": 919.72, "start": 919.68, "text": "well."}, {"end": 921.28, "start": 919.72, "text": "All"}, {"end": 922.96, "start": 921.28, "text": "right."}, {"end": 923.88, "start": 922.96, "text": "OK."}, {"end": 924.96, "start": 923.88, "text": "So"}, {"end": 925.12, "start": 924.96, "text": "let's"}, {"end": 925.32, "start": 925.12, "text": "get"}, {"end": 925.68, "start": 925.32, "text": "started."}, {"end": 925.72, "start": 925.68, "text": "I"}, {"end": 925.84, "start": 925.72, "text": "want"}, {"end": 925.84, "start": 925.84, "text": "to"}, {"end": 926.56, "start": 925.84, "text": "talk"}, {"end": 927.08, "start": 926.56, "text": "about"}, {"end": 927.24, "start": 927.08, "text": "a"}, {"end": 927.8, "start": 927.24, "text": "specific"}, {"end": 928.92, "start": 927.8, "text": "problem"}, {"end": 929.2, "start": 928.92, "text": "and"}, {"end": 929.2, "start": 929.2, "text": "talk"}, {"end": 929.48, "start": 929.2, "text": "about"}, {"end": 929.96, "start": 929.48, "text": "algorithm"}], "text": " A few minutes on the website. In particular, please read the collaboration policy and get a sense of what is expected of you, what the rules are in terms of doing the problem sets, and the course grading breakdown and the grading policies are all listed on the website as well. All right. OK. So let's get started. I want to talk about a specific problem and talk about algorithm"}, {"chunks": [{"end": 930.28, "start": 930.0, "text": "for"}, {"end": 930.44, "start": 930.28, "text": "a"}, {"end": 930.88, "start": 930.44, "text": "specific"}, {"end": 931.84, "start": 930.88, "text": "problem."}, {"end": 932.0, "start": 931.84, "text": "We"}, {"end": 932.12, "start": 932.0, "text": "picked"}, {"end": 932.48, "start": 932.12, "text": "this"}, {"end": 933.0, "start": 932.48, "text": "problem"}, {"end": 933.72, "start": 933.0, "text": "because"}, {"end": 934.04, "start": 933.72, "text": "it's"}, {"end": 934.24, "start": 934.04, "text": "so"}, {"end": 934.4, "start": 934.24, "text": "easy"}, {"end": 934.4, "start": 934.4, "text": "to"}, {"end": 935.56, "start": 934.4, "text": "understand."}, {"end": 936.08, "start": 935.56, "text": "And"}, {"end": 936.44, "start": 936.08, "text": "they're"}, {"end": 936.88, "start": 936.44, "text": "fairly"}, {"end": 937.72, "start": 936.88, "text": "straightforward"}, {"end": 938.52, "start": 937.72, "text": "algorithms"}, {"end": 938.76, "start": 938.52, "text": "that"}, {"end": 939.2, "start": 938.76, "text": "are"}, {"end": 939.28, "start": 939.2, "text": "not"}, {"end": 939.88, "start": 939.28, "text": "particularly"}, {"end": 940.36, "start": 939.88, "text": "efficient"}, {"end": 940.84, "start": 940.36, "text": "to"}, {"end": 941.2, "start": 940.84, "text": "solve"}, {"end": 941.36, "start": 941.2, "text": "this"}, {"end": 942.24, "start": 941.36, "text": "problem."}, {"end": 942.56, "start": 942.24, "text": "And"}, {"end": 942.92, "start": 942.56, "text": "so"}, {"end": 943.28, "start": 942.92, "text": "this"}, {"end": 943.4, "start": 943.28, "text": "is"}, {"end": 943.64, "start": 943.4, "text": "kind"}, {"end": 943.68, "start": 943.64, "text": "of"}, {"end": 943.72, "start": 943.68, "text": "a"}, {"end": 944.04, "start": 943.72, "text": "toy"}, {"end": 945.04, "start": 944.04, "text": "problem."}, {"end": 945.4, "start": 945.04, "text": "But"}, {"end": 946.16, "start": 945.4, "text": "like"}, {"end": 946.4, "start": 946.16, "text": "a"}, {"end": 946.64, "start": 946.4, "text": "lot"}, {"end": 946.72, "start": 946.64, "text": "of"}, {"end": 947.2, "start": 946.72, "text": "toy"}, {"end": 948.88, "start": 947.2, "text": "problems,"}, {"end": 949.44, "start": 948.88, "text": "it's"}, {"end": 950.36, "start": 949.44, "text": "very"}, {"end": 951.4, "start": 950.36, "text": "evocative"}, {"end": 951.52, "start": 951.4, "text": "in"}, {"end": 952.0, "start": 951.52, "text": "that"}, {"end": 952.28, "start": 952.0, "text": "it"}, {"end": 952.68, "start": 952.28, "text": "points"}, {"end": 953.04, "start": 952.68, "text": "out"}, {"end": 953.48, "start": 953.04, "text": "the"}, {"end": 954.04, "start": 953.48, "text": "issues"}, {"end": 955.24, "start": 954.04, "text": "involved"}, {"end": 955.48, "start": 955.24, "text": "in"}, {"end": 956.0, "start": 955.48, "text": "designing"}, {"end": 956.32, "start": 956.0, "text": "efficient"}, {"end": 957.72, "start": 956.32, "text": "algorithms."}, {"end": 957.84, "start": 957.72, "text": "So"}, {"end": 957.96, "start": 957.84, "text": "we'll"}, {"end": 958.24, "start": 957.96, "text": "start"}, {"end": 958.52, "start": 958.24, "text": "with"}, {"end": 958.68, "start": 958.52, "text": "a"}, {"end": 959.24, "start": 958.68, "text": "one-dimensional"}, {"end": 959.96, "start": 959.24, "text": "version."}], "text": " for a specific problem. We picked this problem because it's so easy to understand. And they're fairly straightforward algorithms that are not particularly efficient to solve this problem. And so this is kind of a toy problem. But like a lot of toy problems, it's very evocative in that it points out the issues involved in designing efficient algorithms. So we'll start with a one-dimensional version."}, {"chunks": [{"end": 960.16, "start": 960.0, "text": "of"}, {"end": 960.48, "start": 960.16, "text": "what"}, {"end": 960.56, "start": 960.48, "text": "we"}, {"end": 961.28, "start": 960.56, "text": "call"}, {"end": 962.08, "start": 961.28, "text": "peak"}, {"end": 964.76, "start": 962.08, "text": "finding."}, {"end": 966.0, "start": 964.76, "text": "And"}, {"end": 966.44, "start": 966.0, "text": "a"}, {"end": 966.84, "start": 966.44, "text": "peak"}, {"end": 968.4, "start": 966.84, "text": "finder"}, {"end": 968.72, "start": 968.4, "text": "is"}, {"end": 969.0, "start": 968.72, "text": "something,"}, {"end": 969.52, "start": 969.0, "text": "in"}, {"end": 969.8, "start": 969.52, "text": "the"}, {"end": 970.28, "start": 969.8, "text": "one-dimensional"}, {"end": 972.08, "start": 970.28, "text": "case,"}, {"end": 972.72, "start": 972.08, "text": "runs"}, {"end": 973.36, "start": 972.72, "text": "on"}, {"end": 974.2, "start": 973.36, "text": "an"}, {"end": 975.88, "start": 974.2, "text": "array"}, {"end": 976.04, "start": 975.88, "text": "of"}, {"end": 978.32, "start": 976.04, "text": "numbers."}, {"end": 978.76, "start": 978.32, "text": "And"}, {"end": 979.76, "start": 978.76, "text": "I'm"}, {"end": 980.04, "start": 979.76, "text": "just"}, {"end": 982.76, "start": 980.04, "text": "putting"}, {"end": 983.68, "start": 982.76, "text": "symbols"}, {"end": 984.0, "start": 983.68, "text": "for"}, {"end": 984.52, "start": 984.0, "text": "each"}, {"end": 987.0, "start": 984.52, "text": "of"}, {"end": 988.92, "start": 987.0, "text": "these"}, {"end": 989.28, "start": 988.92, "text": "numbers"}, {"end": 989.96, "start": 989.28, "text": "here."}], "text": " of what we call peak finding. And a peak finder is something, in the one-dimensional case, runs on an array of numbers. And I'm just putting symbols for each of these numbers here."}, {"chunks": [{"end": 990.68, "start": 990.0, "text": "Positive,"}, {"end": 991.6, "start": 990.68, "text": "negative,"}, {"end": 991.8, "start": 991.6, "text": "we'll"}, {"end": 992.0, "start": 991.8, "text": "just"}, {"end": 992.32, "start": 992.0, "text": "assume"}, {"end": 992.68, "start": 992.32, "text": "they're"}, {"end": 992.68, "start": 992.68, "text": "all"}, {"end": 992.92, "start": 992.68, "text": "positive."}, {"end": 992.96, "start": 992.92, "text": "It"}, {"end": 993.36, "start": 992.96, "text": "doesn't"}, {"end": 993.56, "start": 993.36, "text": "really"}, {"end": 994.24, "start": 993.56, "text": "matter."}, {"end": 994.52, "start": 994.24, "text": "The"}, {"end": 995.0, "start": 994.52, "text": "algorithms"}, {"end": 995.12, "start": 995.0, "text": "we"}, {"end": 995.84, "start": 995.12, "text": "describe"}, {"end": 996.36, "start": 995.84, "text": "will"}, {"end": 997.12, "start": 996.36, "text": "work."}, {"end": 997.52, "start": 997.12, "text": "And"}, {"end": 997.92, "start": 997.52, "text": "so"}, {"end": 998.6, "start": 997.92, "text": "we"}, {"end": 999.12, "start": 998.6, "text": "have"}, {"end": 999.84, "start": 999.12, "text": "this"}, {"end": 1000.0, "start": 999.84, "text": "one"}, {"end": 1000.36, "start": 1000.0, "text": "dimensional"}, {"end": 1001.08, "start": 1000.36, "text": "array"}, {"end": 1001.24, "start": 1001.08, "text": "that"}, {"end": 1001.6, "start": 1001.24, "text": "has"}, {"end": 1001.96, "start": 1001.6, "text": "nine"}, {"end": 1002.16, "start": 1001.96, "text": "different"}, {"end": 1003.44, "start": 1002.16, "text": "positions."}, {"end": 1005.08, "start": 1003.44, "text": "And"}, {"end": 1005.32, "start": 1005.08, "text": "a"}, {"end": 1005.64, "start": 1005.32, "text": "through"}, {"end": 1006.84, "start": 1005.64, "text": "i"}, {"end": 1007.24, "start": 1006.84, "text": "are"}, {"end": 1008.28, "start": 1007.24, "text": "numbers."}, {"end": 1009.84, "start": 1008.28, "text": "And"}, {"end": 1010.16, "start": 1009.84, "text": "we"}, {"end": 1010.52, "start": 1010.16, "text": "want"}, {"end": 1010.52, "start": 1010.52, "text": "to"}, {"end": 1010.92, "start": 1010.52, "text": "find"}, {"end": 1011.04, "start": 1010.92, "text": "a"}, {"end": 1011.48, "start": 1011.04, "text": "peak."}, {"end": 1011.6, "start": 1011.48, "text": "And"}, {"end": 1011.84, "start": 1011.6, "text": "so"}, {"end": 1012.04, "start": 1011.84, "text": "we"}, {"end": 1013.16, "start": 1012.04, "text": "have"}, {"end": 1013.56, "start": 1013.16, "text": "to"}, {"end": 1014.0, "start": 1013.56, "text": "define"}, {"end": 1014.16, "start": 1014.0, "text": "what"}, {"end": 1014.32, "start": 1014.16, "text": "we"}, {"end": 1014.52, "start": 1014.32, "text": "mean"}, {"end": 1014.84, "start": 1014.52, "text": "by"}, {"end": 1015.0, "start": 1014.84, "text": "a"}, {"end": 1015.04, "start": 1015.0, "text": "peak."}, {"end": 1015.16, "start": 1015.04, "text": "And"}, {"end": 1017.36, "start": 1015.16, "text": "so"}, {"end": 1017.48, "start": 1017.36, "text": "in"}, {"end": 1017.84, "start": 1017.48, "text": "particular,"}, {"end": 1018.4, "start": 1017.84, "text": "as"}, {"end": 1018.68, "start": 1018.4, "text": "an"}, {"end": 1019.96, "start": 1018.68, "text": "example,"}], "text": " Positive, negative, we'll just assume they're all positive. It doesn't really matter. The algorithms we describe will work. And so we have this one dimensional array that has nine different positions. And a through i are numbers. And we want to find a peak. And so we have to define what we mean by a peak. And so in particular, as an example,"}, {"chunks": [{"end": 1020.92, "start": 1020.0, "text": "Position"}, {"end": 1022.6, "start": 1020.92, "text": "2"}, {"end": 1022.96, "start": 1022.6, "text": "is"}, {"end": 1023.2, "start": 1022.96, "text": "a"}, {"end": 1023.52, "start": 1023.2, "text": "peak"}, {"end": 1023.72, "start": 1023.52, "text": "if"}, {"end": 1026.32, "start": 1023.72, "text": "and"}, {"end": 1026.6, "start": 1026.32, "text": "only"}, {"end": 1026.88, "start": 1026.6, "text": "if"}, {"end": 1027.16, "start": 1026.88, "text": "b"}, {"end": 1029.88, "start": 1027.16, "text": "greater"}, {"end": 1030.76, "start": 1029.88, "text": "than"}, {"end": 1031.96, "start": 1030.76, "text": "or"}, {"end": 1032.2, "start": 1031.96, "text": "equal"}, {"end": 1032.32, "start": 1032.2, "text": "to"}, {"end": 1032.88, "start": 1032.32, "text": "a"}, {"end": 1033.04, "start": 1032.88, "text": "and"}, {"end": 1034.56, "start": 1033.04, "text": "b"}, {"end": 1035.24, "start": 1034.56, "text": "greater"}, {"end": 1035.56, "start": 1035.24, "text": "than"}, {"end": 1035.96, "start": 1035.56, "text": "or"}, {"end": 1036.76, "start": 1035.96, "text": "equal"}, {"end": 1038.0, "start": 1036.76, "text": "to"}, {"end": 1038.04, "start": 1038.0, "text": "c."}, {"end": 1038.4, "start": 1038.04, "text": "So"}, {"end": 1038.6, "start": 1038.4, "text": "it's"}, {"end": 1038.96, "start": 1038.6, "text": "really"}, {"end": 1039.24, "start": 1038.96, "text": "a"}, {"end": 1039.6, "start": 1039.24, "text": "very"}, {"end": 1039.72, "start": 1039.6, "text": "local"}, {"end": 1040.4, "start": 1039.72, "text": "property"}, {"end": 1041.28, "start": 1040.4, "text": "corresponding"}, {"end": 1041.52, "start": 1041.28, "text": "to"}, {"end": 1041.72, "start": 1041.52, "text": "a"}, {"end": 1041.76, "start": 1041.72, "text": "peak."}, {"end": 1041.8, "start": 1041.76, "text": "In"}, {"end": 1042.28, "start": 1041.8, "text": "the"}, {"end": 1043.0, "start": 1042.28, "text": "one-dimensional"}, {"end": 1043.36, "start": 1043.0, "text": "case,"}, {"end": 1043.72, "start": 1043.36, "text": "it's"}, {"end": 1045.0, "start": 1043.72, "text": "trivial."}, {"end": 1045.16, "start": 1045.0, "text": "Look"}, {"end": 1045.2, "start": 1045.16, "text": "to"}, {"end": 1045.72, "start": 1045.2, "text": "your"}, {"end": 1046.2, "start": 1045.72, "text": "left."}, {"end": 1046.32, "start": 1046.2, "text": "Look"}, {"end": 1046.36, "start": 1046.32, "text": "to"}, {"end": 1047.68, "start": 1046.36, "text": "your"}, {"end": 1047.96, "start": 1047.68, "text": "right."}, {"end": 1048.08, "start": 1047.96, "text": "If"}, {"end": 1048.44, "start": 1048.08, "text": "you're"}, {"end": 1048.68, "start": 1048.44, "text": "equal"}, {"end": 1049.0, "start": 1048.68, "text": "or"}, {"end": 1049.36, "start": 1049.0, "text": "greater"}, {"end": 1049.96, "start": 1049.36, "text": "than"}], "text": " Position 2 is a peak if and only if b greater than or equal to a and b greater than or equal to c. So it's really a very local property corresponding to a peak. In the one-dimensional case, it's trivial. Look to your left. Look to your right. If you're equal or greater than"}, {"chunks": [{"end": 1050.0, "start": 1050.0, "text": "Both"}, {"end": 1050.0, "start": 1050.0, "text": "of"}, {"end": 1050.36, "start": 1050.0, "text": "the"}, {"end": 1050.48, "start": 1050.36, "text": "elements"}, {"end": 1050.56, "start": 1050.48, "text": "that"}, {"end": 1050.6, "start": 1050.56, "text": "you"}, {"end": 1051.2, "start": 1050.6, "text": "see"}, {"end": 1051.36, "start": 1051.2, "text": "on"}, {"end": 1052.12, "start": 1051.36, "text": "the"}, {"end": 1052.52, "start": 1052.12, "text": "left"}, {"end": 1052.6, "start": 1052.52, "text": "and"}, {"end": 1053.12, "start": 1052.6, "text": "the"}, {"end": 1053.8, "start": 1053.12, "text": "right,"}, {"end": 1054.08, "start": 1053.8, "text": "you're"}, {"end": 1054.2, "start": 1054.08, "text": "a"}, {"end": 1055.04, "start": 1054.2, "text": "peak."}, {"end": 1055.28, "start": 1055.04, "text": "OK?"}, {"end": 1055.28, "start": 1055.28, "text": "And"}, {"end": 1055.68, "start": 1055.28, "text": "in"}, {"end": 1056.2, "start": 1055.68, "text": "the"}, {"end": 1056.64, "start": 1056.2, "text": "case"}, {"end": 1056.84, "start": 1056.64, "text": "of"}, {"end": 1057.32, "start": 1056.84, "text": "the"}, {"end": 1058.32, "start": 1057.32, "text": "edges,"}, {"end": 1058.4, "start": 1058.32, "text": "you"}, {"end": 1058.8, "start": 1058.4, "text": "only"}, {"end": 1059.08, "start": 1058.8, "text": "have"}, {"end": 1059.08, "start": 1059.08, "text": "to"}, {"end": 1059.08, "start": 1059.08, "text": "look"}, {"end": 1059.16, "start": 1059.08, "text": "to"}, {"end": 1059.44, "start": 1059.16, "text": "one"}, {"end": 1060.72, "start": 1059.44, "text": "side."}, {"end": 1060.88, "start": 1060.72, "text": "So"}, {"end": 1061.4, "start": 1060.88, "text": "position"}, {"end": 1061.84, "start": 1061.4, "text": "9"}, {"end": 1061.88, "start": 1061.84, "text": "is"}, {"end": 1062.16, "start": 1061.88, "text": "a"}, {"end": 1062.44, "start": 1062.16, "text": "peak"}, {"end": 1062.8, "start": 1062.44, "text": "if"}, {"end": 1063.28, "start": 1062.8, "text": "i"}, {"end": 1064.04, "start": 1063.28, "text": "greater"}, {"end": 1064.44, "start": 1064.04, "text": "than"}, {"end": 1065.0, "start": 1064.44, "text": "or"}, {"end": 1065.24, "start": 1065.0, "text": "equal"}, {"end": 1065.56, "start": 1065.24, "text": "to"}, {"end": 1068.32, "start": 1065.56, "text": "h."}, {"end": 1068.6, "start": 1068.32, "text": "So"}, {"end": 1069.0, "start": 1068.6, "text": "you"}, {"end": 1070.24, "start": 1069.0, "text": "just"}, {"end": 1070.6, "start": 1070.24, "text": "have"}, {"end": 1070.92, "start": 1070.6, "text": "to"}, {"end": 1071.44, "start": 1070.92, "text": "look"}, {"end": 1071.76, "start": 1071.44, "text": "to"}, {"end": 1071.96, "start": 1071.76, "text": "your"}, {"end": 1073.52, "start": 1071.96, "text": "left"}, {"end": 1073.68, "start": 1073.52, "text": "there,"}, {"end": 1074.16, "start": 1073.68, "text": "because"}, {"end": 1074.44, "start": 1074.16, "text": "you're"}, {"end": 1074.72, "start": 1074.44, "text": "all"}, {"end": 1074.84, "start": 1074.72, "text": "the"}, {"end": 1075.16, "start": 1074.84, "text": "way"}, {"end": 1075.36, "start": 1075.16, "text": "on"}, {"end": 1075.44, "start": 1075.36, "text": "the"}, {"end": 1076.48, "start": 1075.44, "text": "right-hand"}, {"end": 1076.68, "start": 1076.48, "text": "side."}, {"end": 1077.32, "start": 1076.68, "text": "All"}, {"end": 1077.64, "start": 1077.32, "text": "right?"}, {"end": 1078.6, "start": 1077.64, "text": "So"}, {"end": 1079.08, "start": 1078.6, "text": "that's"}, {"end": 1079.96, "start": 1079.08, "text": "it."}], "text": " Both of the elements that you see on the left and the right, you're a peak. OK? And in the case of the edges, you only have to look to one side. So position 9 is a peak if i greater than or equal to h. So you just have to look to your left there, because you're all the way on the right-hand side. All right? So that's it."}, {"chunks": [{"end": 1080.04, "start": 1080.0, "text": "And"}, {"end": 1080.44, "start": 1080.04, "text": "the"}, {"end": 1081.2, "start": 1080.44, "text": "statement"}, {"end": 1081.68, "start": 1081.2, "text": "of"}, {"end": 1081.92, "start": 1081.68, "text": "the"}, {"end": 1082.92, "start": 1081.92, "text": "problem,"}, {"end": 1083.28, "start": 1082.92, "text": "the"}, {"end": 1083.88, "start": 1083.28, "text": "one-dimensional"}, {"end": 1085.24, "start": 1083.88, "text": "version,"}, {"end": 1087.96, "start": 1085.24, "text": "is"}, {"end": 1088.64, "start": 1087.96, "text": "find"}, {"end": 1089.08, "start": 1088.64, "text": "the"}, {"end": 1089.72, "start": 1089.08, "text": "peak"}, {"end": 1093.0, "start": 1089.72, "text": "if"}, {"end": 1093.36, "start": 1093.0, "text": "it"}, {"end": 1094.16, "start": 1093.36, "text": "exists."}, {"end": 1094.96, "start": 1094.16, "text": "All"}, {"end": 1095.8, "start": 1094.96, "text": "right?"}, {"end": 1096.72, "start": 1095.8, "text": "That's"}, {"end": 1096.92, "start": 1096.72, "text": "all"}, {"end": 1097.6, "start": 1096.92, "text": "there"}, {"end": 1097.8, "start": 1097.6, "text": "is"}, {"end": 1098.68, "start": 1097.8, "text": "to"}, {"end": 1099.56, "start": 1098.68, "text": "it."}, {"end": 1102.0, "start": 1099.56, "text": "I'm"}, {"end": 1102.48, "start": 1102.0, "text": "going"}, {"end": 1103.64, "start": 1102.48, "text": "to"}, {"end": 1104.48, "start": 1103.64, "text": "give"}, {"end": 1104.76, "start": 1104.48, "text": "you"}, {"end": 1105.28, "start": 1104.76, "text": "a"}, {"end": 1107.88, "start": 1105.28, "text": "straightforward"}, {"end": 1108.44, "start": 1107.88, "text": "algorithm."}, {"end": 1108.64, "start": 1108.44, "text": "And"}, {"end": 1109.08, "start": 1108.64, "text": "then"}, {"end": 1109.36, "start": 1109.08, "text": "we'll"}, {"end": 1109.68, "start": 1109.36, "text": "see"}, {"end": 1109.8, "start": 1109.68, "text": "if"}, {"end": 1109.8, "start": 1109.8, "text": "we"}, {"end": 1109.8, "start": 1109.8, "text": "can"}, {"end": 1109.8, "start": 1109.8, "text": "improve"}, {"end": 1109.96, "start": 1109.8, "text": "it."}], "text": " And the statement of the problem, the one-dimensional version, is find the peak if it exists. All right? That's all there is to it. I'm going to give you a straightforward algorithm. And then we'll see if we can improve it."}, {"chunks": [{"end": 1110.12, "start": 1110.0, "text": "You"}, {"end": 1110.12, "start": 1110.12, "text": "can"}, {"end": 1110.96, "start": 1110.12, "text": "imagine"}, {"end": 1111.28, "start": 1110.96, "text": "that"}, {"end": 1111.92, "start": 1111.28, "text": "the"}, {"end": 1113.56, "start": 1111.92, "text": "straightforward"}, {"end": 1113.92, "start": 1113.56, "text": "algorithm"}, {"end": 1114.04, "start": 1113.92, "text": "is"}, {"end": 1114.36, "start": 1114.04, "text": "something"}, {"end": 1114.52, "start": 1114.36, "text": "that"}, {"end": 1115.0, "start": 1114.52, "text": "just"}, {"end": 1115.56, "start": 1115.0, "text": "walks"}, {"end": 1116.88, "start": 1115.56, "text": "across"}, {"end": 1117.08, "start": 1116.88, "text": "the"}, {"end": 1117.64, "start": 1117.08, "text": "array."}, {"end": 1119.4, "start": 1117.64, "text": "But"}, {"end": 1119.96, "start": 1119.4, "text": "we"}, {"end": 1120.12, "start": 1119.96, "text": "need"}, {"end": 1120.36, "start": 1120.12, "text": "that"}, {"end": 1120.6, "start": 1120.36, "text": "as"}, {"end": 1121.12, "start": 1120.6, "text": "a"}, {"end": 1121.44, "start": 1121.12, "text": "starting"}, {"end": 1122.96, "start": 1121.44, "text": "point"}, {"end": 1123.64, "start": 1122.96, "text": "for"}, {"end": 1124.0, "start": 1123.64, "text": "building"}, {"end": 1125.16, "start": 1124.0, "text": "something"}, {"end": 1129.56, "start": 1125.16, "text": "more"}, {"end": 1130.44, "start": 1129.56, "text": "sophisticated."}, {"end": 1130.68, "start": 1130.44, "text": "So"}, {"end": 1136.16, "start": 1130.68, "text": "let's"}, {"end": 1137.0, "start": 1136.16, "text": "say"}, {"end": 1137.12, "start": 1137.0, "text": "we"}, {"end": 1139.0, "start": 1137.12, "text": "start"}, {"end": 1139.4, "start": 1139.0, "text": "from"}, {"end": 1139.96, "start": 1139.4, "text": "left."}], "text": " You can imagine that the straightforward algorithm is something that just walks across the array. But we need that as a starting point for building something more sophisticated. So let's say we start from left."}, {"chunks": [{"end": 1140.36, "start": 1140.0, "text": "One"}, {"end": 1141.16, "start": 1140.36, "text": "traversal,"}, {"end": 1142.08, "start": 1141.16, "text": "really."}, {"end": 1142.36, "start": 1142.08, "text": "So"}, {"end": 1143.16, "start": 1142.36, "text": "let's"}, {"end": 1143.96, "start": 1143.16, "text": "say"}, {"end": 1145.08, "start": 1143.96, "text": "we"}, {"end": 1145.4, "start": 1145.08, "text": "have"}, {"end": 1145.68, "start": 1145.4, "text": "1,"}, {"end": 1146.12, "start": 1145.68, "text": "2,"}, {"end": 1146.44, "start": 1146.12, "text": "and"}, {"end": 1147.0, "start": 1146.44, "text": "then"}, {"end": 1147.12, "start": 1147.0, "text": "we"}, {"end": 1147.68, "start": 1147.12, "text": "have"}, {"end": 1147.84, "start": 1147.68, "text": "n"}, {"end": 1148.44, "start": 1147.84, "text": "over"}, {"end": 1148.64, "start": 1148.44, "text": "2"}, {"end": 1148.96, "start": 1148.64, "text": "over"}, {"end": 1149.52, "start": 1148.96, "text": "here"}, {"end": 1150.72, "start": 1149.52, "text": "corresponding"}, {"end": 1150.72, "start": 1150.72, "text": "to"}, {"end": 1151.04, "start": 1150.72, "text": "the"}, {"end": 1151.48, "start": 1151.04, "text": "middle"}, {"end": 1151.6, "start": 1151.48, "text": "of"}, {"end": 1151.92, "start": 1151.6, "text": "this"}, {"end": 1152.28, "start": 1151.92, "text": "n"}, {"end": 1153.2, "start": 1152.28, "text": "element"}, {"end": 1154.24, "start": 1153.2, "text": "array."}, {"end": 1154.28, "start": 1154.24, "text": "And"}, {"end": 1154.56, "start": 1154.28, "text": "then"}, {"end": 1154.76, "start": 1154.56, "text": "we"}, {"end": 1155.16, "start": 1154.76, "text": "have"}, {"end": 1155.36, "start": 1155.16, "text": "n"}, {"end": 1155.72, "start": 1155.36, "text": "minus"}, {"end": 1157.36, "start": 1155.72, "text": "1"}, {"end": 1157.8, "start": 1157.36, "text": "and"}, {"end": 1157.88, "start": 1157.8, "text": "n."}, {"end": 1157.96, "start": 1157.88, "text": "What"}, {"end": 1159.0, "start": 1157.96, "text": "I'm"}, {"end": 1159.64, "start": 1159.0, "text": "interested"}, {"end": 1159.64, "start": 1159.64, "text": "in"}, {"end": 1160.04, "start": 1159.64, "text": "doing"}, {"end": 1160.48, "start": 1160.04, "text": "is"}, {"end": 1160.68, "start": 1160.48, "text": "not"}, {"end": 1161.04, "start": 1160.68, "text": "only"}, {"end": 1161.36, "start": 1161.04, "text": "coming"}, {"end": 1162.12, "start": 1161.36, "text": "up"}, {"end": 1162.28, "start": 1162.12, "text": "with"}, {"end": 1163.12, "start": 1162.28, "text": "a"}, {"end": 1164.04, "start": 1163.12, "text": "straightforward"}, {"end": 1164.88, "start": 1164.04, "text": "algorithm,"}, {"end": 1165.96, "start": 1164.88, "text": "but"}, {"end": 1166.52, "start": 1165.96, "text": "also"}, {"end": 1167.72, "start": 1166.52, "text": "precisely"}, {"end": 1169.32, "start": 1167.72, "text": "characterizing"}, {"end": 1169.68, "start": 1169.32, "text": "what"}, {"end": 1169.96, "start": 1169.68, "text": "it's"}], "text": " One traversal, really. So let's say we have 1, 2, and then we have n over 2 over here corresponding to the middle of this n element array. And then we have n minus 1 and n. What I'm interested in doing is not only coming up with a straightforward algorithm, but also precisely characterizing what it's"}, {"chunks": [{"end": 1170.6, "start": 1170.0, "text": "Complexity"}, {"end": 1171.36, "start": 1170.6, "text": "is"}, {"end": 1171.56, "start": 1171.36, "text": "in"}, {"end": 1171.96, "start": 1171.56, "text": "relation"}, {"end": 1172.24, "start": 1171.96, "text": "to"}, {"end": 1173.48, "start": 1172.24, "text": "n,"}, {"end": 1173.72, "start": 1173.48, "text": "which"}, {"end": 1174.4, "start": 1173.72, "text": "is"}, {"end": 1174.56, "start": 1174.4, "text": "the"}, {"end": 1174.96, "start": 1174.56, "text": "number"}, {"end": 1175.04, "start": 1174.96, "text": "of"}, {"end": 1175.52, "start": 1175.04, "text": "inputs."}, {"end": 1175.72, "start": 1175.52, "text": "Yeah,"}, {"end": 1176.0, "start": 1175.72, "text": "question?"}, {"end": 1176.0, "start": 1176.0, "text": "Why"}, {"end": 1176.0, "start": 1176.0, "text": "do"}, {"end": 1176.96, "start": 1176.0, "text": "you"}, {"end": 1177.76, "start": 1176.96, "text": "say"}, {"end": 1178.0, "start": 1177.76, "text": "if"}, {"end": 1178.04, "start": 1178.0, "text": "it"}, {"end": 1178.44, "start": 1178.04, "text": "exists,"}, {"end": 1178.44, "start": 1178.44, "text": "would"}, {"end": 1179.0, "start": 1178.44, "text": "the"}, {"end": 1179.48, "start": 1179.0, "text": "criteria"}, {"end": 1179.76, "start": 1179.48, "text": "that"}, {"end": 1179.84, "start": 1179.76, "text": "you"}, {"end": 1179.88, "start": 1179.84, "text": "have"}, {"end": 1180.32, "start": 1179.88, "text": "for"}, {"end": 1180.52, "start": 1180.32, "text": "a"}, {"end": 1180.56, "start": 1180.52, "text": "peak"}, {"end": 1180.56, "start": 1180.56, "text": "?"}, {"end": 1181.2, "start": 1180.56, "text": "That's"}, {"end": 1181.72, "start": 1181.2, "text": "exactly"}, {"end": 1182.32, "start": 1181.72, "text": "right."}, {"end": 1182.68, "start": 1182.32, "text": "I"}, {"end": 1182.72, "start": 1182.68, "text": "was"}, {"end": 1183.68, "start": 1182.72, "text": "going"}, {"end": 1183.72, "start": 1183.68, "text": "to"}, {"end": 1183.92, "start": 1183.72, "text": "get"}, {"end": 1184.04, "start": 1183.92, "text": "to"}, {"end": 1184.48, "start": 1184.04, "text": "that."}, {"end": 1185.56, "start": 1184.48, "text": "So"}, {"end": 1185.64, "start": 1185.56, "text": "if"}, {"end": 1185.64, "start": 1185.64, "text": "you"}, {"end": 1185.68, "start": 1185.64, "text": "look"}, {"end": 1185.84, "start": 1185.68, "text": "at"}, {"end": 1186.28, "start": 1185.84, "text": "the"}, {"end": 1187.64, "start": 1186.28, "text": "definition"}, {"end": 1188.0, "start": 1187.64, "text": "of"}, {"end": 1188.4, "start": 1188.0, "text": "the"}, {"end": 1189.0, "start": 1188.4, "text": "peak,"}, {"end": 1191.2, "start": 1189.0, "text": "then"}, {"end": 1191.84, "start": 1191.2, "text": "what"}, {"end": 1192.44, "start": 1191.84, "text": "I"}, {"end": 1193.28, "start": 1192.44, "text": "have"}, {"end": 1193.44, "start": 1193.28, "text": "here"}, {"end": 1193.44, "start": 1193.44, "text": "is"}, {"end": 1193.76, "start": 1193.44, "text": "greater"}, {"end": 1194.32, "start": 1193.76, "text": "than"}, {"end": 1194.44, "start": 1194.32, "text": "or"}, {"end": 1194.68, "start": 1194.44, "text": "equal"}, {"end": 1195.28, "start": 1194.68, "text": "to."}, {"end": 1196.0, "start": 1195.28, "text": "OK?"}, {"end": 1196.44, "start": 1196.0, "text": "And"}, {"end": 1197.04, "start": 1196.44, "text": "so"}, {"end": 1197.28, "start": 1197.04, "text": "that's"}, {"end": 1197.48, "start": 1197.28, "text": "a"}, {"end": 1197.56, "start": 1197.48, "text": "great"}, {"end": 1198.08, "start": 1197.56, "text": "question"}, {"end": 1198.36, "start": 1198.08, "text": "that"}, {"end": 1198.64, "start": 1198.36, "text": "was"}, {"end": 1199.96, "start": 1198.64, "text": "asked."}], "text": " Complexity is in relation to n, which is the number of inputs. Yeah, question? Why do you say if it exists, would the criteria that you have for a peak ? That's exactly right. I was going to get to that. So if you look at the definition of the peak, then what I have here is greater than or equal to. OK? And so that's a great question that was asked."}, {"chunks": [{"end": 1200.12, "start": 1200.0, "text": "is"}, {"end": 1200.6, "start": 1200.12, "text": "there"}, {"end": 1201.04, "start": 1200.6, "text": "if"}, {"end": 1201.24, "start": 1201.04, "text": "it"}, {"end": 1201.96, "start": 1201.24, "text": "exists"}, {"end": 1202.28, "start": 1201.96, "text": "in"}, {"end": 1202.48, "start": 1202.28, "text": "this"}, {"end": 1204.48, "start": 1202.48, "text": "problem."}, {"end": 1205.6, "start": 1204.48, "text": "Now,"}, {"end": 1205.72, "start": 1205.6, "text": "in"}, {"end": 1205.8, "start": 1205.72, "text": "the"}, {"end": 1206.16, "start": 1205.8, "text": "case"}, {"end": 1206.92, "start": 1206.16, "text": "where"}, {"end": 1207.16, "start": 1206.92, "text": "I"}, {"end": 1207.16, "start": 1207.16, "text": "have"}, {"end": 1207.56, "start": 1207.16, "text": "greater"}, {"end": 1207.6, "start": 1207.56, "text": "than"}, {"end": 1207.6, "start": 1207.6, "text": "or"}, {"end": 1207.64, "start": 1207.6, "text": "equal"}, {"end": 1208.4, "start": 1207.64, "text": "to,"}, {"end": 1208.84, "start": 1208.4, "text": "then"}, {"end": 1208.84, "start": 1208.84, "text": "this"}, {"end": 1209.44, "start": 1208.84, "text": "is"}, {"end": 1210.08, "start": 1209.44, "text": "a"}, {"end": 1210.6, "start": 1210.08, "text": "homework"}, {"end": 1211.0, "start": 1210.6, "text": "question"}, {"end": 1211.36, "start": 1211.0, "text": "for"}, {"end": 1211.36, "start": 1211.36, "text": "you"}, {"end": 1211.48, "start": 1211.36, "text": "and"}, {"end": 1212.2, "start": 1211.48, "text": "for"}, {"end": 1212.44, "start": 1212.2, "text": "the"}, {"end": 1212.76, "start": 1212.44, "text": "rest"}, {"end": 1212.8, "start": 1212.76, "text": "of"}, {"end": 1213.6, "start": 1212.8, "text": "you."}, {"end": 1214.24, "start": 1213.6, "text": "Argue"}, {"end": 1214.8, "start": 1214.24, "text": "that"}, {"end": 1215.8, "start": 1214.8, "text": "any"}, {"end": 1217.72, "start": 1215.8, "text": "array"}, {"end": 1217.76, "start": 1217.72, "text": "will"}, {"end": 1218.16, "start": 1217.76, "text": "always"}, {"end": 1218.48, "start": 1218.16, "text": "have"}, {"end": 1218.6, "start": 1218.48, "text": "a"}, {"end": 1219.6, "start": 1218.6, "text": "peak."}, {"end": 1220.76, "start": 1219.6, "text": "OK?"}, {"end": 1221.24, "start": 1220.76, "text": "Now,"}, {"end": 1221.64, "start": 1221.24, "text": "if"}, {"end": 1221.64, "start": 1221.64, "text": "you"}, {"end": 1221.64, "start": 1221.64, "text": "didn't"}, {"end": 1221.64, "start": 1221.64, "text": "have"}, {"end": 1222.12, "start": 1221.64, "text": "the"}, {"end": 1222.6, "start": 1222.12, "text": "greater"}, {"end": 1223.32, "start": 1222.6, "text": "than"}, {"end": 1223.56, "start": 1223.32, "text": "or"}, {"end": 1223.76, "start": 1223.56, "text": "equal"}, {"end": 1224.12, "start": 1223.76, "text": "to,"}, {"end": 1224.16, "start": 1224.12, "text": "and"}, {"end": 1224.16, "start": 1224.16, "text": "you"}, {"end": 1224.28, "start": 1224.16, "text": "had"}, {"end": 1224.76, "start": 1224.28, "text": "a"}, {"end": 1225.08, "start": 1224.76, "text": "greater"}, {"end": 1225.08, "start": 1225.08, "text": "than,"}, {"end": 1225.36, "start": 1225.08, "text": "then"}, {"end": 1225.36, "start": 1225.36, "text": "can"}, {"end": 1226.08, "start": 1225.36, "text": "you"}, {"end": 1226.92, "start": 1226.08, "text": "make"}, {"end": 1227.52, "start": 1226.92, "text": "that"}, {"end": 1229.0, "start": 1227.52, "text": "argument?"}, {"end": 1229.2, "start": 1229.0, "text": "No,"}, {"end": 1229.28, "start": 1229.2, "text": "you"}, {"end": 1229.96, "start": 1229.28, "text": "can."}], "text": " is there if it exists in this problem. Now, in the case where I have greater than or equal to, then this is a homework question for you and for the rest of you. Argue that any array will always have a peak. OK? Now, if you didn't have the greater than or equal to, and you had a greater than, then can you make that argument? No, you can."}, {"chunks": [{"end": 1230.84, "start": 1230.0, "text": "Right?"}, {"end": 1231.64, "start": 1230.84, "text": "So"}, {"end": 1232.12, "start": 1231.64, "text": "great"}, {"end": 1232.88, "start": 1232.12, "text": "question."}, {"end": 1232.88, "start": 1232.88, "text": "In"}, {"end": 1233.12, "start": 1232.88, "text": "this"}, {"end": 1233.68, "start": 1233.12, "text": "case,"}, {"end": 1234.16, "start": 1233.68, "text": "it's"}, {"end": 1234.56, "start": 1234.16, "text": "just"}, {"end": 1234.88, "start": 1234.56, "text": "a"}, {"end": 1235.36, "start": 1234.88, "text": "question."}, {"end": 1235.36, "start": 1235.36, "text": "You"}, {"end": 1235.68, "start": 1235.36, "text": "would"}, {"end": 1235.84, "start": 1235.68, "text": "want"}, {"end": 1236.16, "start": 1235.84, "text": "to"}, {"end": 1236.92, "start": 1236.16, "text": "modify"}, {"end": 1237.04, "start": 1236.92, "text": "this"}, {"end": 1237.36, "start": 1237.04, "text": "problem"}, {"end": 1237.72, "start": 1237.36, "text": "statement"}, {"end": 1237.88, "start": 1237.72, "text": "to"}, {"end": 1238.2, "start": 1237.88, "text": "find"}, {"end": 1238.36, "start": 1238.2, "text": "a"}, {"end": 1238.96, "start": 1238.36, "text": "peak."}, {"end": 1239.12, "start": 1238.96, "text": "But"}, {"end": 1239.24, "start": 1239.12, "text": "if"}, {"end": 1240.24, "start": 1239.24, "text": "I"}, {"end": 1240.8, "start": 1240.24, "text": "had"}, {"end": 1240.88, "start": 1240.8, "text": "a"}, {"end": 1241.52, "start": 1240.88, "text": "different"}, {"end": 1242.12, "start": 1241.52, "text": "definition"}, {"end": 1242.24, "start": 1242.12, "text": "of"}, {"end": 1242.4, "start": 1242.24, "text": "a"}, {"end": 1242.88, "start": 1242.4, "text": "peak,"}, {"end": 1243.28, "start": 1242.88, "text": "and"}, {"end": 1243.32, "start": 1243.28, "text": "this"}, {"end": 1243.8, "start": 1243.32, "text": "is"}, {"end": 1244.16, "start": 1243.8, "text": "part"}, {"end": 1244.32, "start": 1244.16, "text": "of"}, {"end": 1244.76, "start": 1244.32, "text": "algorithmic"}, {"end": 1244.88, "start": 1244.76, "text": "thinking,"}, {"end": 1245.44, "start": 1244.88, "text": "you"}, {"end": 1245.76, "start": 1245.44, "text": "want"}, {"end": 1245.84, "start": 1245.76, "text": "to"}, {"end": 1246.12, "start": 1245.84, "text": "be"}, {"end": 1246.4, "start": 1246.12, "text": "able"}, {"end": 1247.0, "start": 1246.4, "text": "to"}, {"end": 1248.24, "start": 1247.0, "text": "create"}, {"end": 1248.8, "start": 1248.24, "text": "algorithms"}, {"end": 1248.96, "start": 1248.8, "text": "that"}, {"end": 1249.04, "start": 1248.96, "text": "are"}, {"end": 1249.52, "start": 1249.04, "text": "general."}, {"end": 1250.16, "start": 1249.52, "text": "So"}, {"end": 1250.2, "start": 1250.16, "text": "if"}, {"end": 1250.32, "start": 1250.2, "text": "the"}, {"end": 1250.68, "start": 1250.32, "text": "problem"}, {"end": 1251.16, "start": 1250.68, "text": "definition"}, {"end": 1251.6, "start": 1251.16, "text": "changes"}, {"end": 1251.76, "start": 1251.6, "text": "on"}, {"end": 1251.76, "start": 1251.76, "text": "you,"}, {"end": 1252.0, "start": 1251.76, "text": "you"}, {"end": 1252.84, "start": 1252.0, "text": "still"}, {"end": 1253.2, "start": 1252.84, "text": "have"}, {"end": 1253.2, "start": 1253.2, "text": "a"}, {"end": 1253.44, "start": 1253.2, "text": "starting"}, {"end": 1253.48, "start": 1253.44, "text": "point"}, {"end": 1253.6, "start": 1253.48, "text": "to"}, {"end": 1253.84, "start": 1253.6, "text": "go"}, {"end": 1254.24, "start": 1253.84, "text": "attack"}, {"end": 1254.64, "start": 1254.24, "text": "the"}, {"end": 1255.12, "start": 1254.64, "text": "second"}, {"end": 1255.4, "start": 1255.12, "text": "version"}, {"end": 1255.48, "start": 1255.4, "text": "of"}, {"end": 1255.56, "start": 1255.48, "text": "the"}, {"end": 1256.44, "start": 1255.56, "text": "problem."}, {"end": 1257.28, "start": 1256.44, "text": "OK?"}, {"end": 1257.8, "start": 1257.28, "text": "So"}, {"end": 1257.84, "start": 1257.8, "text": "you"}, {"end": 1259.48, "start": 1257.84, "text": "could"}, {"end": 1259.96, "start": 1259.48, "text": "eliminate"}], "text": " Right? So great question. In this case, it's just a question. You would want to modify this problem statement to find a peak. But if I had a different definition of a peak, and this is part of algorithmic thinking, you want to be able to create algorithms that are general. So if the problem definition changes on you, you still have a starting point to go attack the second version of the problem. OK? So you could eliminate"}, {"chunks": [{"end": 1260.12, "start": 1260.0, "text": "And"}, {"end": 1260.6, "start": 1260.12, "text": "this,"}, {"end": 1261.24, "start": 1260.6, "text": "in"}, {"end": 1261.36, "start": 1261.24, "text": "the"}, {"end": 1261.76, "start": 1261.36, "text": "case"}, {"end": 1261.88, "start": 1261.76, "text": "of"}, {"end": 1261.96, "start": 1261.88, "text": "the"}, {"end": 1262.44, "start": 1261.96, "text": "greater"}, {"end": 1262.52, "start": 1262.44, "text": "than"}, {"end": 1262.64, "start": 1262.52, "text": "or"}, {"end": 1263.0, "start": 1262.64, "text": "equal"}, {"end": 1263.24, "start": 1263.0, "text": "to"}, {"end": 1263.44, "start": 1263.24, "text": "definition,"}, {"end": 1263.64, "start": 1263.44, "text": "the"}, {"end": 1263.64, "start": 1263.64, "text": "if"}, {"end": 1263.64, "start": 1263.64, "text": "it"}, {"end": 1264.04, "start": 1263.64, "text": "exists,"}, {"end": 1264.28, "start": 1264.04, "text": "because"}, {"end": 1264.28, "start": 1264.28, "text": "the"}, {"end": 1264.44, "start": 1264.28, "text": "peak"}, {"end": 1264.52, "start": 1264.44, "text": "will"}, {"end": 1265.0, "start": 1264.52, "text": "always"}, {"end": 1265.36, "start": 1265.0, "text": "exist."}, {"end": 1265.52, "start": 1265.36, "text": "But"}, {"end": 1265.6, "start": 1265.52, "text": "you"}, {"end": 1265.92, "start": 1265.6, "text": "probably"}, {"end": 1265.96, "start": 1265.92, "text": "want"}, {"end": 1266.0, "start": 1265.96, "text": "to"}, {"end": 1266.32, "start": 1266.0, "text": "argue"}, {"end": 1266.72, "start": 1266.32, "text": "that"}, {"end": 1267.12, "start": 1266.72, "text": "when"}, {"end": 1267.12, "start": 1267.12, "text": "you"}, {"end": 1267.12, "start": 1267.12, "text": "want"}, {"end": 1267.56, "start": 1267.12, "text": "to"}, {"end": 1267.84, "start": 1267.56, "text": "show"}, {"end": 1267.84, "start": 1267.84, "text": "the"}, {"end": 1268.36, "start": 1267.84, "text": "correctness"}, {"end": 1268.44, "start": 1268.36, "text": "of"}, {"end": 1268.84, "start": 1268.44, "text": "your"}, {"end": 1269.72, "start": 1268.84, "text": "algorithm."}, {"end": 1269.92, "start": 1269.72, "text": "And"}, {"end": 1270.16, "start": 1269.92, "text": "if,"}, {"end": 1270.36, "start": 1270.16, "text": "in"}, {"end": 1270.36, "start": 1270.36, "text": "fact,"}, {"end": 1270.44, "start": 1270.36, "text": "you"}, {"end": 1270.76, "start": 1270.44, "text": "had"}, {"end": 1270.88, "start": 1270.76, "text": "a"}, {"end": 1271.64, "start": 1270.88, "text": "different"}, {"end": 1273.16, "start": 1271.64, "text": "definition,"}, {"end": 1273.96, "start": 1273.16, "text": "well,"}, {"end": 1274.44, "start": 1273.96, "text": "you"}, {"end": 1275.2, "start": 1274.44, "text": "would"}, {"end": 1275.56, "start": 1275.2, "text": "have"}, {"end": 1275.64, "start": 1275.56, "text": "to"}, {"end": 1276.68, "start": 1275.64, "text": "create"}, {"end": 1277.36, "start": 1276.68, "text": "an"}, {"end": 1278.08, "start": 1277.36, "text": "algorithm"}, {"end": 1278.48, "start": 1278.08, "text": "that"}, {"end": 1278.92, "start": 1278.48, "text": "tells"}, {"end": 1279.08, "start": 1278.92, "text": "you"}, {"end": 1279.2, "start": 1279.08, "text": "for"}, {"end": 1279.92, "start": 1279.2, "text": "sure"}, {"end": 1280.2, "start": 1279.92, "text": "that"}, {"end": 1280.36, "start": 1280.2, "text": "a"}, {"end": 1280.6, "start": 1280.36, "text": "peak"}, {"end": 1280.92, "start": 1280.6, "text": "doesn't"}, {"end": 1281.72, "start": 1280.92, "text": "exist"}, {"end": 1281.96, "start": 1281.72, "text": "or"}, {"end": 1282.36, "start": 1281.96, "text": "find"}, {"end": 1282.6, "start": 1282.36, "text": "a"}, {"end": 1282.68, "start": 1282.6, "text": "peak"}, {"end": 1282.92, "start": 1282.68, "text": "if"}, {"end": 1283.16, "start": 1282.92, "text": "it"}, {"end": 1283.8, "start": 1283.16, "text": "exists."}, {"end": 1284.32, "start": 1283.8, "text": "So"}, {"end": 1284.72, "start": 1284.32, "text": "that's"}, {"end": 1284.88, "start": 1284.72, "text": "really"}, {"end": 1284.96, "start": 1284.88, "text": "the"}, {"end": 1285.24, "start": 1284.96, "text": "general"}, {"end": 1286.28, "start": 1285.24, "text": "case."}, {"end": 1286.56, "start": 1286.28, "text": "Many"}, {"end": 1286.8, "start": 1286.56, "text": "a"}, {"end": 1287.24, "start": 1286.8, "text": "time,"}, {"end": 1287.4, "start": 1287.24, "text": "it's"}, {"end": 1287.84, "start": 1287.4, "text": "possible"}, {"end": 1288.04, "start": 1287.84, "text": "that"}, {"end": 1288.44, "start": 1288.04, "text": "you're"}, {"end": 1288.92, "start": 1288.44, "text": "asked"}, {"end": 1289.2, "start": 1288.92, "text": "to"}, {"end": 1289.44, "start": 1289.2, "text": "do"}, {"end": 1289.96, "start": 1289.44, "text": "something."}], "text": " And this, in the case of the greater than or equal to definition, the if it exists, because the peak will always exist. But you probably want to argue that when you want to show the correctness of your algorithm. And if, in fact, you had a different definition, well, you would have to create an algorithm that tells you for sure that a peak doesn't exist or find a peak if it exists. So that's really the general case. Many a time, it's possible that you're asked to do something."}, {"chunks": [{"end": 1290.12, "start": 1290.0, "text": "You"}, {"end": 1290.28, "start": 1290.12, "text": "can't"}, {"end": 1291.56, "start": 1290.28, "text": "actually"}, {"end": 1291.88, "start": 1291.56, "text": "give"}, {"end": 1292.08, "start": 1291.88, "text": "an"}, {"end": 1293.36, "start": 1292.08, "text": "answer"}, {"end": 1293.76, "start": 1293.36, "text": "to"}, {"end": 1294.0, "start": 1293.76, "text": "the"}, {"end": 1294.88, "start": 1294.0, "text": "question"}, {"end": 1295.12, "start": 1294.88, "text": "or"}, {"end": 1295.48, "start": 1295.12, "text": "find"}, {"end": 1295.88, "start": 1295.48, "text": "something"}, {"end": 1296.08, "start": 1295.88, "text": "that"}, {"end": 1296.76, "start": 1296.08, "text": "satisfies"}, {"end": 1297.08, "start": 1296.76, "text": "all"}, {"end": 1297.48, "start": 1297.08, "text": "the"}, {"end": 1298.68, "start": 1297.48, "text": "constraints"}, {"end": 1299.24, "start": 1298.68, "text": "required."}, {"end": 1299.56, "start": 1299.24, "text": "And"}, {"end": 1299.72, "start": 1299.56, "text": "in"}, {"end": 1299.92, "start": 1299.72, "text": "that"}, {"end": 1300.4, "start": 1299.92, "text": "case,"}, {"end": 1300.72, "start": 1300.4, "text": "you"}, {"end": 1300.88, "start": 1300.72, "text": "want"}, {"end": 1300.92, "start": 1300.88, "text": "to"}, {"end": 1300.92, "start": 1300.92, "text": "be"}, {"end": 1300.92, "start": 1300.92, "text": "able"}, {"end": 1300.92, "start": 1300.92, "text": "to"}, {"end": 1301.0, "start": 1300.92, "text": "put"}, {"end": 1301.16, "start": 1301.0, "text": "up"}, {"end": 1301.36, "start": 1301.16, "text": "your"}, {"end": 1301.6, "start": 1301.36, "text": "hand"}, {"end": 1301.76, "start": 1301.6, "text": "and"}, {"end": 1302.08, "start": 1301.76, "text": "say,"}, {"end": 1302.6, "start": 1302.08, "text": "you"}, {"end": 1303.08, "start": 1302.6, "text": "know"}, {"end": 1303.48, "start": 1303.08, "text": "what?"}, {"end": 1303.6, "start": 1303.48, "text": "I"}, {"end": 1303.92, "start": 1303.6, "text": "searched"}, {"end": 1304.36, "start": 1303.92, "text": "long"}, {"end": 1304.8, "start": 1304.36, "text": "and"}, {"end": 1304.88, "start": 1304.8, "text": "hard."}, {"end": 1305.0, "start": 1304.88, "text": "I"}, {"end": 1305.44, "start": 1305.0, "text": "searched"}, {"end": 1306.72, "start": 1305.44, "text": "exhaustively."}, {"end": 1306.96, "start": 1306.72, "text": "Here's"}, {"end": 1307.32, "start": 1306.96, "text": "my"}, {"end": 1308.08, "start": 1307.32, "text": "argument"}, {"end": 1308.28, "start": 1308.08, "text": "that"}, {"end": 1308.68, "start": 1308.28, "text": "I"}, {"end": 1309.12, "start": 1308.68, "text": "searched"}, {"end": 1310.08, "start": 1309.12, "text": "exhaustively,"}, {"end": 1310.48, "start": 1310.08, "text": "and"}, {"end": 1310.64, "start": 1310.48, "text": "I"}, {"end": 1311.24, "start": 1310.64, "text": "couldn't"}, {"end": 1311.88, "start": 1311.24, "text": "find"}, {"end": 1312.32, "start": 1311.88, "text": "it."}, {"end": 1312.6, "start": 1312.32, "text": "If"}, {"end": 1312.72, "start": 1312.6, "text": "you"}, {"end": 1312.88, "start": 1312.72, "text": "do"}, {"end": 1313.44, "start": 1312.88, "text": "that,"}, {"end": 1313.44, "start": 1313.44, "text": "you"}, {"end": 1313.72, "start": 1313.44, "text": "get"}, {"end": 1313.96, "start": 1313.72, "text": "to"}, {"end": 1314.2, "start": 1313.96, "text": "keep"}, {"end": 1314.48, "start": 1314.2, "text": "your"}, {"end": 1314.56, "start": 1314.48, "text": "job."}, {"end": 1315.2, "start": 1314.56, "text": "Otherwise,"}, {"end": 1316.12, "start": 1315.2, "text": "there's"}, {"end": 1316.4, "start": 1316.12, "text": "always"}, {"end": 1316.72, "start": 1316.4, "text": "the"}, {"end": 1317.32, "start": 1316.72, "text": "case"}, {"end": 1317.36, "start": 1317.32, "text": "that"}, {"end": 1317.44, "start": 1317.36, "text": "you"}, {"end": 1317.68, "start": 1317.44, "text": "didn't"}, {"end": 1318.08, "start": 1317.68, "text": "search"}, {"end": 1318.36, "start": 1318.08, "text": "hard"}, {"end": 1319.04, "start": 1318.36, "text": "enough."}, {"end": 1319.16, "start": 1319.04, "text": "So"}, {"end": 1319.24, "start": 1319.16, "text": "it's"}, {"end": 1319.48, "start": 1319.24, "text": "nice"}, {"end": 1319.72, "start": 1319.48, "text": "to"}, {"end": 1319.72, "start": 1319.72, "text": "have"}, {"end": 1319.72, "start": 1319.72, "text": "that"}, {"end": 1319.96, "start": 1319.72, "text": "argument."}], "text": " You can't actually give an answer to the question or find something that satisfies all the constraints required. And in that case, you want to be able to put up your hand and say, you know what? I searched long and hard. I searched exhaustively. Here's my argument that I searched exhaustively, and I couldn't find it. If you do that, you get to keep your job. Otherwise, there's always the case that you didn't search hard enough. So it's nice to have that argument."}, {"chunks": [{"end": 1322.24, "start": 1320.0, "text": "All"}, {"end": 1322.68, "start": 1322.24, "text": "right,"}, {"end": 1323.0, "start": 1322.68, "text": "great."}, {"end": 1323.24, "start": 1323.0, "text": "Thanks"}, {"end": 1323.36, "start": 1323.24, "text": "for"}, {"end": 1323.36, "start": 1323.36, "text": "the"}, {"end": 1324.16, "start": 1323.36, "text": "question."}, {"end": 1324.36, "start": 1324.16, "text": "Feel"}, {"end": 1324.64, "start": 1324.36, "text": "free"}, {"end": 1324.64, "start": 1324.64, "text": "to"}, {"end": 1325.16, "start": 1324.64, "text": "interrupt."}, {"end": 1325.6, "start": 1325.16, "text": "Raise"}, {"end": 1326.04, "start": 1325.6, "text": "your"}, {"end": 1326.28, "start": 1326.04, "text": "hand."}, {"end": 1326.72, "start": 1326.28, "text": "And"}, {"end": 1327.08, "start": 1326.72, "text": "I'm"}, {"end": 1327.44, "start": 1327.08, "text": "watching"}, {"end": 1327.48, "start": 1327.44, "text": "you"}, {"end": 1327.88, "start": 1327.48, "text": "guys,"}, {"end": 1327.96, "start": 1327.88, "text": "and"}, {"end": 1328.08, "start": 1327.96, "text": "I'm"}, {"end": 1328.16, "start": 1328.08, "text": "happy"}, {"end": 1328.2, "start": 1328.16, "text": "to"}, {"end": 1328.56, "start": 1328.2, "text": "answer"}, {"end": 1329.04, "start": 1328.56, "text": "questions"}, {"end": 1329.16, "start": 1329.04, "text": "at"}, {"end": 1329.44, "start": 1329.16, "text": "any"}, {"end": 1330.88, "start": 1329.44, "text": "time."}, {"end": 1331.36, "start": 1330.88, "text": "So"}, {"end": 1331.4, "start": 1331.36, "text": "let's"}, {"end": 1332.0, "start": 1331.4, "text": "talk"}, {"end": 1332.48, "start": 1332.0, "text": "about"}, {"end": 1332.92, "start": 1332.48, "text": "the"}, {"end": 1333.68, "start": 1332.92, "text": "straightforward"}, {"end": 1333.96, "start": 1333.68, "text": "algorithm."}, {"end": 1334.36, "start": 1333.96, "text": "The"}, {"end": 1334.96, "start": 1334.36, "text": "straightforward"}, {"end": 1336.04, "start": 1334.96, "text": "algorithm"}, {"end": 1336.56, "start": 1336.04, "text": "is"}, {"end": 1337.12, "start": 1336.56, "text": "something"}, {"end": 1337.52, "start": 1337.12, "text": "that"}, {"end": 1337.84, "start": 1337.52, "text": "starts"}, {"end": 1337.84, "start": 1337.84, "text": "from"}, {"end": 1337.84, "start": 1337.84, "text": "the"}, {"end": 1338.28, "start": 1337.84, "text": "left"}, {"end": 1338.84, "start": 1338.28, "text": "and"}, {"end": 1339.0, "start": 1338.84, "text": "just"}, {"end": 1339.4, "start": 1339.0, "text": "walks"}, {"end": 1340.68, "start": 1339.4, "text": "across."}, {"end": 1341.8, "start": 1340.68, "text": "And"}, {"end": 1341.84, "start": 1341.8, "text": "you"}, {"end": 1342.2, "start": 1341.84, "text": "might"}, {"end": 1342.76, "start": 1342.2, "text": "have"}, {"end": 1343.36, "start": 1342.76, "text": "something"}, {"end": 1343.72, "start": 1343.36, "text": "that"}, {"end": 1344.56, "start": 1343.72, "text": "looks"}, {"end": 1344.84, "start": 1344.56, "text": "like"}, {"end": 1344.92, "start": 1344.84, "text": "that."}, {"end": 1345.2, "start": 1344.92, "text": "By"}, {"end": 1345.6, "start": 1345.2, "text": "this,"}, {"end": 1346.0, "start": 1345.6, "text": "I"}, {"end": 1346.4, "start": 1346.0, "text": "mean"}, {"end": 1346.48, "start": 1346.4, "text": "the"}, {"end": 1347.08, "start": 1346.48, "text": "numbers"}, {"end": 1347.16, "start": 1347.08, "text": "are"}, {"end": 1347.68, "start": 1347.16, "text": "increasing"}, {"end": 1347.96, "start": 1347.68, "text": "as"}, {"end": 1348.12, "start": 1347.96, "text": "you"}, {"end": 1348.44, "start": 1348.12, "text": "start"}, {"end": 1348.6, "start": 1348.44, "text": "from"}, {"end": 1348.68, "start": 1348.6, "text": "the"}, {"end": 1349.0, "start": 1348.68, "text": "left,"}, {"end": 1349.52, "start": 1349.0, "text": "and"}, {"end": 1349.64, "start": 1349.52, "text": "the"}, {"end": 1349.96, "start": 1349.64, "text": "peak"}], "text": " All right, great. Thanks for the question. Feel free to interrupt. Raise your hand. And I'm watching you guys, and I'm happy to answer questions at any time. So let's talk about the straightforward algorithm. The straightforward algorithm is something that starts from the left and just walks across. And you might have something that looks like that. By this, I mean the numbers are increasing as you start from the left, and the peak"}, {"chunks": [{"end": 1350.28, "start": 1350.0, "text": "is"}, {"end": 1351.72, "start": 1350.28, "text": "somewhere"}, {"end": 1352.28, "start": 1351.72, "text": "in"}, {"end": 1352.64, "start": 1352.28, "text": "the"}, {"end": 1352.8, "start": 1352.64, "text": "middle,"}, {"end": 1353.8, "start": 1352.8, "text": "and"}, {"end": 1354.0, "start": 1353.8, "text": "then"}, {"end": 1354.04, "start": 1354.0, "text": "things"}, {"end": 1354.56, "start": 1354.04, "text": "start"}, {"end": 1355.4, "start": 1354.56, "text": "decreasing."}, {"end": 1356.52, "start": 1355.4, "text": "So"}, {"end": 1356.6, "start": 1356.52, "text": "in"}, {"end": 1356.8, "start": 1356.6, "text": "this"}, {"end": 1358.12, "start": 1356.8, "text": "case,"}, {"end": 1358.6, "start": 1358.12, "text": "this"}, {"end": 1359.12, "start": 1358.6, "text": "might"}, {"end": 1359.64, "start": 1359.12, "text": "be"}, {"end": 1359.84, "start": 1359.64, "text": "the"}, {"end": 1363.6, "start": 1359.84, "text": "peak."}, {"end": 1364.56, "start": 1363.6, "text": "You"}, {"end": 1366.84, "start": 1364.56, "text": "also"}, {"end": 1367.12, "start": 1366.84, "text": "may"}, {"end": 1367.6, "start": 1367.12, "text": "have"}, {"end": 1367.92, "start": 1367.6, "text": "a"}, {"end": 1368.44, "start": 1367.92, "text": "situation"}, {"end": 1368.92, "start": 1368.44, "text": "where"}, {"end": 1369.0, "start": 1368.92, "text": "the"}, {"end": 1369.32, "start": 1369.0, "text": "peak"}, {"end": 1369.52, "start": 1369.32, "text": "is"}, {"end": 1369.56, "start": 1369.52, "text": "all"}, {"end": 1369.76, "start": 1369.56, "text": "the"}, {"end": 1370.08, "start": 1369.76, "text": "way"}, {"end": 1370.52, "start": 1370.08, "text": "on"}, {"end": 1370.64, "start": 1370.52, "text": "the"}, {"end": 1371.2, "start": 1370.64, "text": "right."}, {"end": 1371.28, "start": 1371.2, "text": "You"}, {"end": 1371.64, "start": 1371.28, "text": "started"}, {"end": 1371.76, "start": 1371.64, "text": "from"}, {"end": 1371.88, "start": 1371.76, "text": "the"}, {"end": 1372.32, "start": 1371.88, "text": "left,"}, {"end": 1372.8, "start": 1372.32, "text": "and"}, {"end": 1373.24, "start": 1372.8, "text": "it's"}, {"end": 1373.4, "start": 1373.24, "text": "1,"}, {"end": 1373.6, "start": 1373.4, "text": "2,"}, {"end": 1373.76, "start": 1373.6, "text": "3,"}, {"end": 1373.96, "start": 1373.76, "text": "4,"}, {"end": 1374.24, "start": 1373.96, "text": "5,"}, {"end": 1374.56, "start": 1374.24, "text": "6,"}, {"end": 1375.08, "start": 1374.56, "text": "literally"}, {"end": 1375.08, "start": 1375.08, "text": "in"}, {"end": 1375.4, "start": 1375.08, "text": "terms"}, {"end": 1375.4, "start": 1375.4, "text": "of"}, {"end": 1375.44, "start": 1375.4, "text": "the"}, {"end": 1376.4, "start": 1375.44, "text": "numbers."}, {"end": 1376.68, "start": 1376.4, "text": "And"}, {"end": 1377.16, "start": 1376.68, "text": "you're"}, {"end": 1377.4, "start": 1377.16, "text": "going"}, {"end": 1377.4, "start": 1377.4, "text": "to"}, {"end": 1377.44, "start": 1377.4, "text": "look"}, {"end": 1378.24, "start": 1377.44, "text": "at"}, {"end": 1378.36, "start": 1378.24, "text": "n"}, {"end": 1379.96, "start": 1378.36, "text": "elements"}], "text": " is somewhere in the middle, and then things start decreasing. So in this case, this might be the peak. You also may have a situation where the peak is all the way on the right. You started from the left, and it's 1, 2, 3, 4, 5, 6, literally in terms of the numbers. And you're going to look at n elements"}, {"chunks": [{"end": 1380.24, "start": 1380.0, "text": "going"}, {"end": 1380.4, "start": 1380.24, "text": "all"}, {"end": 1381.12, "start": 1380.4, "text": "the"}, {"end": 1381.48, "start": 1381.12, "text": "way"}, {"end": 1381.6, "start": 1381.48, "text": "to"}, {"end": 1382.12, "start": 1381.6, "text": "the"}, {"end": 1382.28, "start": 1382.12, "text": "right"}, {"end": 1382.48, "start": 1382.28, "text": "in"}, {"end": 1382.88, "start": 1382.48, "text": "order"}, {"end": 1383.24, "start": 1382.88, "text": "to"}, {"end": 1383.56, "start": 1383.24, "text": "find"}, {"end": 1383.6, "start": 1383.56, "text": "the"}, {"end": 1384.76, "start": 1383.6, "text": "peak."}, {"end": 1385.2, "start": 1384.76, "text": "So"}, {"end": 1385.2, "start": 1385.2, "text": "in"}, {"end": 1385.24, "start": 1385.2, "text": "the"}, {"end": 1385.68, "start": 1385.24, "text": "case"}, {"end": 1386.64, "start": 1385.68, "text": "of"}, {"end": 1387.08, "start": 1386.64, "text": "the"}, {"end": 1387.56, "start": 1387.08, "text": "middle,"}, {"end": 1387.92, "start": 1387.56, "text": "you'd"}, {"end": 1388.2, "start": 1387.92, "text": "look"}, {"end": 1388.52, "start": 1388.2, "text": "at"}, {"end": 1389.16, "start": 1388.52, "text": "n"}, {"end": 1389.56, "start": 1389.16, "text": "over"}, {"end": 1390.52, "start": 1389.56, "text": "2"}, {"end": 1391.24, "start": 1390.52, "text": "elements"}, {"end": 1392.04, "start": 1391.24, "text": "if"}, {"end": 1392.4, "start": 1392.04, "text": "it"}, {"end": 1392.72, "start": 1392.4, "text": "was"}, {"end": 1393.8, "start": 1392.72, "text": "right"}, {"end": 1394.12, "start": 1393.8, "text": "in"}, {"end": 1394.48, "start": 1394.12, "text": "the"}, {"end": 1398.4, "start": 1394.48, "text": "middle."}, {"end": 1398.88, "start": 1398.4, "text": "And"}, {"end": 1399.32, "start": 1398.88, "text": "the"}, {"end": 1399.68, "start": 1399.32, "text": "worst"}, {"end": 1400.08, "start": 1399.68, "text": "case"}, {"end": 1402.6, "start": 1400.08, "text": "complexity"}, {"end": 1405.0, "start": 1402.6, "text": "is"}, {"end": 1406.24, "start": 1405.0, "text": "what"}, {"end": 1406.72, "start": 1406.24, "text": "we"}, {"end": 1407.28, "start": 1406.72, "text": "call"}, {"end": 1409.8, "start": 1407.28, "text": "theta"}, {"end": 1409.96, "start": 1409.8, "text": "n."}], "text": " going all the way to the right in order to find the peak. So in the case of the middle, you'd look at n over 2 elements if it was right in the middle. And the worst case complexity is what we call theta n."}, {"chunks": [{"end": 1410.52, "start": 1410.0, "text": "And"}, {"end": 1410.72, "start": 1410.52, "text": "it's"}, {"end": 1410.8, "start": 1410.72, "text": "theta"}, {"end": 1411.84, "start": 1410.8, "text": "n"}, {"end": 1412.32, "start": 1411.84, "text": "because"}, {"end": 1412.44, "start": 1412.32, "text": "in"}, {"end": 1412.56, "start": 1412.44, "text": "the"}, {"end": 1412.8, "start": 1412.56, "text": "worst"}, {"end": 1413.56, "start": 1412.8, "text": "case,"}, {"end": 1413.64, "start": 1413.56, "text": "you"}, {"end": 1414.04, "start": 1413.64, "text": "may"}, {"end": 1414.28, "start": 1414.04, "text": "have"}, {"end": 1414.56, "start": 1414.28, "text": "to"}, {"end": 1414.6, "start": 1414.56, "text": "look"}, {"end": 1414.84, "start": 1414.6, "text": "at"}, {"end": 1415.12, "start": 1414.84, "text": "all"}, {"end": 1415.36, "start": 1415.12, "text": "n"}, {"end": 1416.0, "start": 1415.36, "text": "elements."}, {"end": 1416.0, "start": 1416.0, "text": "And"}, {"end": 1416.04, "start": 1416.0, "text": "that"}, {"end": 1416.04, "start": 1416.04, "text": "would"}, {"end": 1416.28, "start": 1416.04, "text": "be"}, {"end": 1416.88, "start": 1416.28, "text": "the"}, {"end": 1417.2, "start": 1416.88, "text": "case"}, {"end": 1417.32, "start": 1417.2, "text": "where"}, {"end": 1417.44, "start": 1417.32, "text": "you"}, {"end": 1417.76, "start": 1417.44, "text": "started"}, {"end": 1417.88, "start": 1417.76, "text": "from"}, {"end": 1417.92, "start": 1417.88, "text": "the"}, {"end": 1418.28, "start": 1417.92, "text": "left"}, {"end": 1418.36, "start": 1418.28, "text": "and"}, {"end": 1418.44, "start": 1418.36, "text": "you"}, {"end": 1418.44, "start": 1418.44, "text": "had"}, {"end": 1418.8, "start": 1418.44, "text": "to"}, {"end": 1419.16, "start": 1418.8, "text": "go"}, {"end": 1419.68, "start": 1419.16, "text": "all"}, {"end": 1419.72, "start": 1419.68, "text": "the"}, {"end": 1420.12, "start": 1419.72, "text": "way"}, {"end": 1420.12, "start": 1420.12, "text": "to"}, {"end": 1420.6, "start": 1420.12, "text": "the"}, {"end": 1420.8, "start": 1420.6, "text": "right."}, {"end": 1421.12, "start": 1420.8, "text": "Now"}, {"end": 1421.36, "start": 1421.12, "text": "remember,"}, {"end": 1421.72, "start": 1421.36, "text": "theta"}, {"end": 1422.04, "start": 1421.72, "text": "n"}, {"end": 1422.8, "start": 1422.04, "text": "is"}, {"end": 1423.32, "start": 1422.8, "text": "essentially"}, {"end": 1423.64, "start": 1423.32, "text": "something"}, {"end": 1423.92, "start": 1423.64, "text": "that"}, {"end": 1424.64, "start": 1423.92, "text": "says"}, {"end": 1424.76, "start": 1424.64, "text": "of"}, {"end": 1425.12, "start": 1424.76, "text": "the"}, {"end": 1425.56, "start": 1425.12, "text": "order"}, {"end": 1425.6, "start": 1425.56, "text": "of"}, {"end": 1425.8, "start": 1425.6, "text": "n."}, {"end": 1426.0, "start": 1425.8, "text": "So"}, {"end": 1426.04, "start": 1426.0, "text": "it"}, {"end": 1426.24, "start": 1426.04, "text": "gives"}, {"end": 1426.44, "start": 1426.24, "text": "you"}, {"end": 1426.56, "start": 1426.44, "text": "both"}, {"end": 1426.64, "start": 1426.56, "text": "the"}, {"end": 1427.04, "start": 1426.64, "text": "lower"}, {"end": 1427.44, "start": 1427.04, "text": "bound"}, {"end": 1428.0, "start": 1427.44, "text": "and"}, {"end": 1428.28, "start": 1428.0, "text": "an"}, {"end": 1428.32, "start": 1428.28, "text": "upper"}, {"end": 1429.4, "start": 1428.32, "text": "bound."}, {"end": 1429.44, "start": 1429.4, "text": "Big"}, {"end": 1429.6, "start": 1429.44, "text": "O"}, {"end": 1429.88, "start": 1429.6, "text": "of"}, {"end": 1430.16, "start": 1429.88, "text": "n"}, {"end": 1430.68, "start": 1430.16, "text": "is"}, {"end": 1430.84, "start": 1430.68, "text": "just"}, {"end": 1431.0, "start": 1430.84, "text": "the"}, {"end": 1431.12, "start": 1431.0, "text": "upper"}, {"end": 1431.4, "start": 1431.12, "text": "bound."}, {"end": 1432.0, "start": 1431.4, "text": "And"}, {"end": 1432.4, "start": 1432.0, "text": "what"}, {"end": 1433.08, "start": 1432.4, "text": "we're"}, {"end": 1433.4, "start": 1433.08, "text": "saying"}, {"end": 1433.68, "start": 1433.4, "text": "here"}, {"end": 1433.8, "start": 1433.68, "text": "is"}, {"end": 1433.92, "start": 1433.8, "text": "we're"}, {"end": 1434.32, "start": 1433.92, "text": "saying"}, {"end": 1435.56, "start": 1434.32, "text": "this"}, {"end": 1436.32, "start": 1435.56, "text": "algorithm"}, {"end": 1436.68, "start": 1436.32, "text": "that"}, {"end": 1437.68, "start": 1436.68, "text": "starts"}, {"end": 1438.0, "start": 1437.68, "text": "from"}, {"end": 1438.08, "start": 1438.0, "text": "the"}, {"end": 1438.28, "start": 1438.08, "text": "left"}, {"end": 1438.28, "start": 1438.28, "text": "is"}, {"end": 1438.6, "start": 1438.28, "text": "going"}, {"end": 1438.92, "start": 1438.6, "text": "to"}, {"end": 1439.96, "start": 1438.92, "text": "essentially"}], "text": " And it's theta n because in the worst case, you may have to look at all n elements. And that would be the case where you started from the left and you had to go all the way to the right. Now remember, theta n is essentially something that says of the order of n. So it gives you both the lower bound and an upper bound. Big O of n is just the upper bound. And what we're saying here is we're saying this algorithm that starts from the left is going to essentially"}, {"chunks": [{"end": 1441.28, "start": 1440.0, "text": "Require"}, {"end": 1441.44, "start": 1441.28, "text": "in"}, {"end": 1441.84, "start": 1441.44, "text": "the"}, {"end": 1442.16, "start": 1441.84, "text": "worst"}, {"end": 1443.44, "start": 1442.16, "text": "case"}, {"end": 1443.92, "start": 1443.44, "text": "something"}, {"end": 1444.88, "start": 1443.92, "text": "that's"}, {"end": 1444.96, "start": 1444.88, "text": "a"}, {"end": 1445.44, "start": 1444.96, "text": "constant"}, {"end": 1446.64, "start": 1445.44, "text": "times"}, {"end": 1446.72, "start": 1446.64, "text": "n."}, {"end": 1447.2, "start": 1446.72, "text": "OK?"}, {"end": 1447.64, "start": 1447.2, "text": "And"}, {"end": 1448.08, "start": 1447.64, "text": "that"}, {"end": 1448.72, "start": 1448.08, "text": "constant"}, {"end": 1448.92, "start": 1448.72, "text": "could"}, {"end": 1449.68, "start": 1448.92, "text": "be"}, {"end": 1450.8, "start": 1449.68, "text": "1."}, {"end": 1451.12, "start": 1450.8, "text": "You"}, {"end": 1451.12, "start": 1451.12, "text": "could"}, {"end": 1451.44, "start": 1451.12, "text": "certainly"}, {"end": 1451.84, "start": 1451.44, "text": "set"}, {"end": 1452.12, "start": 1451.84, "text": "things"}, {"end": 1452.16, "start": 1452.12, "text": "up"}, {"end": 1452.36, "start": 1452.16, "text": "that"}, {"end": 1453.08, "start": 1452.36, "text": "way."}, {"end": 1453.28, "start": 1453.08, "text": "Or"}, {"end": 1453.28, "start": 1453.28, "text": "if"}, {"end": 1453.36, "start": 1453.28, "text": "you"}, {"end": 1453.88, "start": 1453.36, "text": "had"}, {"end": 1453.96, "start": 1453.88, "text": "a"}, {"end": 1454.2, "start": 1453.96, "text": "different"}, {"end": 1454.68, "start": 1454.2, "text": "kind"}, {"end": 1454.88, "start": 1454.68, "text": "of"}, {"end": 1455.84, "start": 1454.88, "text": "algorithm,"}, {"end": 1456.2, "start": 1455.84, "text": "maybe"}, {"end": 1456.32, "start": 1456.2, "text": "you"}, {"end": 1456.6, "start": 1456.32, "text": "could"}, {"end": 1456.96, "start": 1456.6, "text": "work"}, {"end": 1457.24, "start": 1456.96, "text": "on"}, {"end": 1457.52, "start": 1457.24, "text": "the"}, {"end": 1458.44, "start": 1457.52, "text": "constant."}, {"end": 1459.16, "start": 1458.44, "text": "But"}, {"end": 1459.4, "start": 1459.16, "text": "bottom"}, {"end": 1459.68, "start": 1459.4, "text": "line,"}, {"end": 1460.4, "start": 1459.68, "text": "we're"}, {"end": 1460.76, "start": 1460.4, "text": "only"}, {"end": 1461.44, "start": 1460.76, "text": "concerned"}, {"end": 1461.52, "start": 1461.44, "text": "at"}, {"end": 1461.8, "start": 1461.52, "text": "this"}, {"end": 1462.32, "start": 1461.8, "text": "moment"}, {"end": 1463.2, "start": 1462.32, "text": "about"}, {"end": 1463.72, "start": 1463.2, "text": "asymptotic"}, {"end": 1464.76, "start": 1463.72, "text": "complexity."}, {"end": 1465.0, "start": 1464.76, "text": "And"}, {"end": 1465.08, "start": 1465.0, "text": "the"}, {"end": 1465.6, "start": 1465.08, "text": "asymptotic"}, {"end": 1466.16, "start": 1465.6, "text": "complexity"}, {"end": 1466.2, "start": 1466.16, "text": "of"}, {"end": 1466.6, "start": 1466.2, "text": "this"}, {"end": 1467.32, "start": 1466.6, "text": "algorithm"}, {"end": 1467.76, "start": 1467.32, "text": "is"}, {"end": 1469.0, "start": 1467.76, "text": "linear."}, {"end": 1469.68, "start": 1469.0, "text": "All"}, {"end": 1469.96, "start": 1469.68, "text": "right?"}], "text": " Require in the worst case something that's a constant times n. OK? And that constant could be 1. You could certainly set things up that way. Or if you had a different kind of algorithm, maybe you could work on the constant. But bottom line, we're only concerned at this moment about asymptotic complexity. And the asymptotic complexity of this algorithm is linear. All right?"}, {"chunks": [{"end": 1471.96, "start": 1470.0, "text": "OK."}, {"end": 1472.92, "start": 1471.96, "text": "So"}, {"end": 1476.32, "start": 1472.92, "text": "someone"}, {"end": 1476.76, "start": 1476.32, "text": "help"}, {"end": 1477.28, "start": 1476.76, "text": "me"}, {"end": 1477.4, "start": 1477.28, "text": "do"}, {"end": 1477.6, "start": 1477.4, "text": "better."}, {"end": 1478.84, "start": 1477.6, "text": "How"}, {"end": 1479.08, "start": 1478.84, "text": "can"}, {"end": 1479.2, "start": 1479.08, "text": "we"}, {"end": 1479.36, "start": 1479.2, "text": "do"}, {"end": 1479.72, "start": 1479.36, "text": "better?"}, {"end": 1479.92, "start": 1479.72, "text": "How"}, {"end": 1480.0, "start": 1479.92, "text": "can"}, {"end": 1480.28, "start": 1480.0, "text": "we"}, {"end": 1481.12, "start": 1480.28, "text": "lower"}, {"end": 1481.36, "start": 1481.12, "text": "the"}, {"end": 1481.8, "start": 1481.36, "text": "asymptotic"}, {"end": 1482.32, "start": 1481.8, "text": "complexity"}, {"end": 1482.4, "start": 1482.32, "text": "of"}, {"end": 1482.92, "start": 1482.4, "text": "a"}, {"end": 1483.2, "start": 1482.92, "text": "one"}, {"end": 1484.0, "start": 1483.2, "text": "dimensional"}, {"end": 1484.24, "start": 1484.0, "text": "peak"}, {"end": 1484.44, "start": 1484.24, "text": "finder?"}, {"end": 1484.56, "start": 1484.44, "text": "Anybody"}, {"end": 1484.64, "start": 1484.56, "text": "want"}, {"end": 1484.68, "start": 1484.64, "text": "to"}, {"end": 1486.92, "start": 1484.68, "text": "take"}, {"end": 1487.48, "start": 1486.92, "text": "a"}, {"end": 1487.84, "start": 1487.48, "text": "stab"}, {"end": 1488.04, "start": 1487.84, "text": "at"}, {"end": 1488.44, "start": 1488.04, "text": "that?"}, {"end": 1488.76, "start": 1488.44, "text": "Yeah,"}, {"end": 1489.68, "start": 1488.76, "text": "back"}, {"end": 1490.2, "start": 1489.68, "text": "there."}, {"end": 1490.48, "start": 1490.2, "text": "Do"}, {"end": 1490.72, "start": 1490.48, "text": "a"}, {"end": 1491.12, "start": 1490.72, "text": "binary"}, {"end": 1491.64, "start": 1491.12, "text": "search"}, {"end": 1492.04, "start": 1491.64, "text": "such"}, {"end": 1492.28, "start": 1492.04, "text": "that"}, {"end": 1492.64, "start": 1492.28, "text": "you"}, {"end": 1492.84, "start": 1492.64, "text": "look"}, {"end": 1492.84, "start": 1492.84, "text": "at"}, {"end": 1492.92, "start": 1492.84, "text": "the"}, {"end": 1493.56, "start": 1492.92, "text": "middle"}, {"end": 1493.72, "start": 1493.56, "text": "and"}, {"end": 1494.08, "start": 1493.72, "text": "whatever"}, {"end": 1494.24, "start": 1494.08, "text": "is"}, {"end": 1495.56, "start": 1494.24, "text": "higher,"}, {"end": 1495.92, "start": 1495.56, "text": "whichever"}, {"end": 1496.24, "start": 1495.92, "text": "side"}, {"end": 1496.28, "start": 1496.24, "text": "is"}, {"end": 1496.76, "start": 1496.28, "text": "higher,"}, {"end": 1497.2, "start": 1496.76, "text": "you"}, {"end": 1497.36, "start": 1497.2, "text": "then"}, {"end": 1497.76, "start": 1497.36, "text": "cut"}, {"end": 1497.8, "start": 1497.76, "text": "that"}, {"end": 1497.88, "start": 1497.8, "text": "in"}, {"end": 1498.28, "start": 1497.88, "text": "half"}, {"end": 1498.36, "start": 1498.28, "text": "because"}, {"end": 1498.48, "start": 1498.36, "text": "you"}, {"end": 1498.68, "start": 1498.48, "text": "know"}, {"end": 1498.84, "start": 1498.68, "text": "there's"}, {"end": 1499.0, "start": 1498.84, "text": "a"}, {"end": 1499.96, "start": 1499.0, "text": "peak."}], "text": " OK. So someone help me do better. How can we do better? How can we lower the asymptotic complexity of a one dimensional peak finder? Anybody want to take a stab at that? Yeah, back there. Do a binary search such that you look at the middle and whatever is higher, whichever side is higher, you then cut that in half because you know there's a peak."}, {"chunks": [{"end": 1500.2, "start": 1500.0, "text": "For"}, {"end": 1500.88, "start": 1500.2, "text": "example,"}, {"end": 1501.04, "start": 1500.88, "text": "if"}, {"end": 1501.56, "start": 1501.04, "text": "you're"}, {"end": 1501.76, "start": 1501.56, "text": "in"}, {"end": 1502.32, "start": 1501.76, "text": "the"}, {"end": 1502.32, "start": 1502.32, "text": "middle"}, {"end": 1502.32, "start": 1502.32, "text": "on"}, {"end": 1502.32, "start": 1502.32, "text": "the"}, {"end": 1502.32, "start": 1502.32, "text": "right"}, {"end": 1502.32, "start": 1502.32, "text": "side,"}, {"end": 1502.64, "start": 1502.32, "text": "there's"}, {"end": 1502.92, "start": 1502.64, "text": "a"}, {"end": 1503.32, "start": 1502.92, "text": "higher"}, {"end": 1503.6, "start": 1503.32, "text": "number"}, {"end": 1503.6, "start": 1503.6, "text": "on"}, {"end": 1503.64, "start": 1503.6, "text": "the"}, {"end": 1503.88, "start": 1503.64, "text": "right"}, {"end": 1504.28, "start": 1503.88, "text": "side,"}, {"end": 1504.44, "start": 1504.28, "text": "then"}, {"end": 1504.44, "start": 1504.44, "text": "you"}, {"end": 1504.64, "start": 1504.44, "text": "would"}, {"end": 1504.92, "start": 1504.64, "text": "just"}, {"end": 1505.08, "start": 1504.92, "text": "look"}, {"end": 1505.08, "start": 1505.08, "text": "at"}, {"end": 1505.08, "start": 1505.08, "text": "that"}, {"end": 1505.08, "start": 1505.08, "text": "because"}, {"end": 1505.08, "start": 1505.08, "text": "you"}, {"end": 1505.08, "start": 1505.08, "text": "know"}, {"end": 1505.52, "start": 1505.08, "text": "there"}, {"end": 1505.92, "start": 1505.52, "text": "would"}, {"end": 1506.12, "start": 1505.92, "text": "peak"}, {"end": 1506.4, "start": 1506.12, "text": "somewhere"}, {"end": 1506.4, "start": 1506.4, "text": "in"}, {"end": 1507.04, "start": 1506.4, "text": "there,"}, {"end": 1507.44, "start": 1507.04, "text": "and"}, {"end": 1507.56, "start": 1507.44, "text": "you"}, {"end": 1507.92, "start": 1507.56, "text": "continue"}, {"end": 1508.28, "start": 1507.92, "text": "cutting"}, {"end": 1508.28, "start": 1508.28, "text": "it"}, {"end": 1508.32, "start": 1508.28, "text": "in"}, {"end": 1508.88, "start": 1508.32, "text": "half."}, {"end": 1509.72, "start": 1508.88, "text": "Excellent."}, {"end": 1510.8, "start": 1509.72, "text": "Excellent."}, {"end": 1511.2, "start": 1510.8, "text": "That's"}, {"end": 1512.2, "start": 1511.2, "text": "exactly"}, {"end": 1512.8, "start": 1512.2, "text": "right."}, {"end": 1513.08, "start": 1512.8, "text": "So"}, {"end": 1513.4, "start": 1513.08, "text": "you"}, {"end": 1513.64, "start": 1513.4, "text": "can"}, {"end": 1513.8, "start": 1513.64, "text": "do"}, {"end": 1514.12, "start": 1513.8, "text": "something"}, {"end": 1514.6, "start": 1514.12, "text": "different,"}, {"end": 1514.8, "start": 1514.6, "text": "which"}, {"end": 1515.84, "start": 1514.8, "text": "is"}, {"end": 1516.32, "start": 1515.84, "text": "essentially"}, {"end": 1516.92, "start": 1516.32, "text": "try"}, {"end": 1518.16, "start": 1516.92, "text": "and"}, {"end": 1518.56, "start": 1518.16, "text": "break"}, {"end": 1518.6, "start": 1518.56, "text": "up"}, {"end": 1518.76, "start": 1518.6, "text": "this"}, {"end": 1519.2, "start": 1518.76, "text": "problem,"}, {"end": 1519.48, "start": 1519.2, "text": "use"}, {"end": 1519.48, "start": 1519.48, "text": "a"}, {"end": 1519.88, "start": 1519.48, "text": "divide"}, {"end": 1519.92, "start": 1519.88, "text": "and"}, {"end": 1520.32, "start": 1519.92, "text": "conquer"}, {"end": 1521.4, "start": 1520.32, "text": "strategy,"}, {"end": 1521.76, "start": 1521.4, "text": "and"}, {"end": 1522.32, "start": 1521.76, "text": "recursively"}, {"end": 1522.6, "start": 1522.32, "text": "break"}, {"end": 1522.96, "start": 1522.6, "text": "up"}, {"end": 1523.28, "start": 1522.96, "text": "this"}, {"end": 1523.56, "start": 1523.28, "text": "one"}, {"end": 1524.0, "start": 1523.56, "text": "dimensional"}, {"end": 1524.88, "start": 1524.0, "text": "array"}, {"end": 1524.96, "start": 1524.88, "text": "into"}, {"end": 1525.64, "start": 1524.96, "text": "smaller"}, {"end": 1526.56, "start": 1525.64, "text": "arrays,"}, {"end": 1526.96, "start": 1526.56, "text": "and"}, {"end": 1527.6, "start": 1526.96, "text": "try"}, {"end": 1528.08, "start": 1527.6, "text": "and"}, {"end": 1528.28, "start": 1528.08, "text": "get"}, {"end": 1529.04, "start": 1528.28, "text": "this"}, {"end": 1529.4, "start": 1529.04, "text": "complexity"}, {"end": 1529.96, "start": 1529.4, "text": "down."}], "text": " For example, if you're in the middle on the right side, there's a higher number on the right side, then you would just look at that because you know there would peak somewhere in there, and you continue cutting it in half. Excellent. Excellent. That's exactly right. So you can do something different, which is essentially try and break up this problem, use a divide and conquer strategy, and recursively break up this one dimensional array into smaller arrays, and try and get this complexity down."}, {"chunks": [{"end": 1530.68, "start": 1530.0, "text": "Yeah?"}, {"end": 1531.2, "start": 1530.68, "text": "Are"}, {"end": 1531.2, "start": 1531.2, "text": "we"}, {"end": 1531.24, "start": 1531.2, "text": "assuming"}, {"end": 1531.48, "start": 1531.24, "text": "there's"}, {"end": 1531.76, "start": 1531.48, "text": "only"}, {"end": 1532.08, "start": 1531.76, "text": "one"}, {"end": 1533.44, "start": 1532.08, "text": "peak?"}, {"end": 1533.44, "start": 1533.44, "text": "No,"}, {"end": 1533.44, "start": 1533.44, "text": "we're"}, {"end": 1534.24, "start": 1533.44, "text": "not."}, {"end": 1534.96, "start": 1534.24, "text": "OK."}, {"end": 1536.16, "start": 1534.96, "text": "It's"}, {"end": 1536.8, "start": 1536.16, "text": "find"}, {"end": 1537.0, "start": 1536.8, "text": "a"}, {"end": 1537.04, "start": 1537.0, "text": "peak"}, {"end": 1537.08, "start": 1537.04, "text": "if"}, {"end": 1537.48, "start": 1537.08, "text": "it"}, {"end": 1538.36, "start": 1537.48, "text": "exists."}, {"end": 1538.56, "start": 1538.36, "text": "And"}, {"end": 1539.0, "start": 1538.56, "text": "in"}, {"end": 1539.6, "start": 1539.0, "text": "this"}, {"end": 1540.0, "start": 1539.6, "text": "case,"}, {"end": 1540.16, "start": 1540.0, "text": "it's"}, {"end": 1540.76, "start": 1540.16, "text": "find"}, {"end": 1541.04, "start": 1540.76, "text": "a"}, {"end": 1541.04, "start": 1541.04, "text": "peak"}, {"end": 1541.12, "start": 1541.04, "text": "because"}, {"end": 1541.16, "start": 1541.12, "text": "of"}, {"end": 1541.6, "start": 1541.16, "text": "the"}, {"end": 1542.32, "start": 1541.6, "text": "definition."}, {"end": 1542.56, "start": 1542.32, "text": "We"}, {"end": 1542.56, "start": 1542.56, "text": "don't"}, {"end": 1542.88, "start": 1542.56, "text": "really"}, {"end": 1543.2, "start": 1542.88, "text": "need"}, {"end": 1543.64, "start": 1543.2, "text": "this"}, {"end": 1544.04, "start": 1543.64, "text": "as"}, {"end": 1544.72, "start": 1544.04, "text": "it"}, {"end": 1544.96, "start": 1544.72, "text": "was"}, {"end": 1545.56, "start": 1544.96, "text": "discussed."}, {"end": 1545.88, "start": 1545.56, "text": "All"}, {"end": 1546.6, "start": 1545.88, "text": "right?"}, {"end": 1547.16, "start": 1546.6, "text": "OK."}, {"end": 1549.04, "start": 1547.16, "text": "So"}, {"end": 1549.32, "start": 1549.04, "text": "that"}, {"end": 1550.48, "start": 1549.32, "text": "was"}, {"end": 1550.88, "start": 1550.48, "text": "a"}, {"end": 1551.24, "start": 1550.88, "text": "great"}, {"end": 1551.8, "start": 1551.24, "text": "answer."}, {"end": 1552.08, "start": 1551.8, "text": "And"}, {"end": 1552.24, "start": 1552.08, "text": "this"}, {"end": 1553.6, "start": 1552.24, "text": "class,"}, {"end": 1554.24, "start": 1553.6, "text": "after"}, {"end": 1554.48, "start": 1554.24, "text": "a"}, {"end": 1554.72, "start": 1554.48, "text": "while,"}, {"end": 1554.76, "start": 1554.72, "text": "is"}, {"end": 1555.0, "start": 1554.76, "text": "going"}, {"end": 1555.0, "start": 1555.0, "text": "to"}, {"end": 1555.0, "start": 1555.0, "text": "get"}, {"end": 1555.4, "start": 1555.0, "text": "boring,"}, {"end": 1555.76, "start": 1555.4, "text": "right?"}, {"end": 1555.88, "start": 1555.76, "text": "Every"}, {"end": 1556.2, "start": 1555.88, "text": "class"}, {"end": 1556.36, "start": 1556.2, "text": "gets"}, {"end": 1557.6, "start": 1556.36, "text": "boring."}, {"end": 1558.08, "start": 1557.6, "text": "So"}, {"end": 1558.24, "start": 1558.08, "text": "we"}, {"end": 1558.52, "start": 1558.24, "text": "try"}, {"end": 1558.6, "start": 1558.52, "text": "and"}, {"end": 1558.88, "start": 1558.6, "text": "break"}, {"end": 1559.0, "start": 1558.88, "text": "the"}, {"end": 1559.52, "start": 1559.0, "text": "monotony"}, {"end": 1559.6, "start": 1559.52, "text": "here"}, {"end": 1559.84, "start": 1559.6, "text": "a"}, {"end": 1559.96, "start": 1559.84, "text": "bit."}], "text": " Yeah? Are we assuming there's only one peak? No, we're not. OK. It's find a peak if it exists. And in this case, it's find a peak because of the definition. We don't really need this as it was discussed. All right? OK. So that was a great answer. And this class, after a while, is going to get boring, right? Every class gets boring. So we try and break the monotony here a bit."}, {"chunks": [{"end": 1560.16, "start": 1560.0, "text": "And"}, {"end": 1560.48, "start": 1560.16, "text": "so,"}, {"end": 1560.56, "start": 1560.48, "text": "and"}, {"end": 1560.56, "start": 1560.56, "text": "then"}, {"end": 1560.64, "start": 1560.56, "text": "the"}, {"end": 1561.48, "start": 1560.64, "text": "other"}, {"end": 1561.76, "start": 1561.48, "text": "thing"}, {"end": 1562.08, "start": 1561.76, "text": "that"}, {"end": 1562.32, "start": 1562.08, "text": "we"}, {"end": 1562.76, "start": 1562.32, "text": "realized"}, {"end": 1562.92, "start": 1562.76, "text": "was"}, {"end": 1563.08, "start": 1562.92, "text": "that"}, {"end": 1563.4, "start": 1563.08, "text": "these"}, {"end": 1563.8, "start": 1563.4, "text": "seats"}, {"end": 1563.92, "start": 1563.8, "text": "you're"}, {"end": 1564.44, "start": 1563.92, "text": "sitting"}, {"end": 1564.56, "start": 1564.44, "text": "on,"}, {"end": 1564.56, "start": 1564.56, "text": "this"}, {"end": 1564.76, "start": 1564.56, "text": "is"}, {"end": 1564.8, "start": 1564.76, "text": "a"}, {"end": 1565.04, "start": 1564.8, "text": "nice"}, {"end": 1565.68, "start": 1565.04, "text": "classroom,"}, {"end": 1566.04, "start": 1565.68, "text": "but"}, {"end": 1566.08, "start": 1566.04, "text": "the"}, {"end": 1566.44, "start": 1566.08, "text": "seats"}, {"end": 1566.76, "start": 1566.44, "text": "you're"}, {"end": 1566.76, "start": 1566.76, "text": "sitting"}, {"end": 1566.84, "start": 1566.76, "text": "on"}, {"end": 1567.36, "start": 1566.84, "text": "are"}, {"end": 1567.4, "start": 1567.36, "text": "kind"}, {"end": 1567.88, "start": 1567.4, "text": "of"}, {"end": 1568.12, "start": 1567.88, "text": "hard."}, {"end": 1568.52, "start": 1568.12, "text": "So"}, {"end": 1568.52, "start": 1568.52, "text": "what"}, {"end": 1568.72, "start": 1568.52, "text": "Eric"}, {"end": 1569.08, "start": 1568.72, "text": "and"}, {"end": 1569.36, "start": 1569.08, "text": "I"}, {"end": 1569.56, "start": 1569.36, "text": "did"}, {"end": 1569.96, "start": 1569.56, "text": "was"}, {"end": 1570.24, "start": 1569.96, "text": "we"}, {"end": 1570.92, "start": 1570.24, "text": "decided"}, {"end": 1571.08, "start": 1570.92, "text": "we'll"}, {"end": 1571.24, "start": 1571.08, "text": "help"}, {"end": 1571.32, "start": 1571.24, "text": "you"}, {"end": 1571.6, "start": 1571.32, "text": "guys"}, {"end": 1571.88, "start": 1571.6, "text": "out,"}, {"end": 1572.48, "start": 1571.88, "text": "especially"}, {"end": 1573.44, "start": 1572.48, "text": "the"}, {"end": 1573.8, "start": 1573.44, "text": "ones"}, {"end": 1574.16, "start": 1573.8, "text": "who"}, {"end": 1574.64, "start": 1574.16, "text": "are"}, {"end": 1575.24, "start": 1574.64, "text": "interacting"}, {"end": 1575.28, "start": 1575.24, "text": "with"}, {"end": 1575.88, "start": 1575.28, "text": "us."}, {"end": 1576.24, "start": 1575.88, "text": "And"}, {"end": 1576.68, "start": 1576.24, "text": "we"}, {"end": 1577.12, "start": 1576.68, "text": "have"}, {"end": 1577.8, "start": 1577.12, "text": "these"}, {"end": 1579.4, "start": 1577.8, "text": "cushions"}, {"end": 1579.84, "start": 1579.4, "text": "that"}, {"end": 1580.16, "start": 1579.84, "text": "are"}, {"end": 1581.8, "start": 1580.16, "text": "6.006"}, {"end": 1582.36, "start": 1581.8, "text": "cushions."}, {"end": 1582.56, "start": 1582.36, "text": "And"}, {"end": 1582.92, "start": 1582.56, "text": "that's"}, {"end": 1582.92, "start": 1582.92, "text": "a"}, {"end": 1583.08, "start": 1582.92, "text": "two"}, {"end": 1583.24, "start": 1583.08, "text": "by"}, {"end": 1583.4, "start": 1583.24, "text": "two"}, {"end": 1583.56, "start": 1583.4, "text": "by"}, {"end": 1583.84, "start": 1583.56, "text": "two"}, {"end": 1584.04, "start": 1583.84, "text": "Rubik's"}, {"end": 1584.28, "start": 1584.04, "text": "cube"}, {"end": 1584.56, "start": 1584.28, "text": "here."}, {"end": 1585.44, "start": 1584.56, "text": "And"}, {"end": 1585.72, "start": 1585.44, "text": "since"}, {"end": 1585.96, "start": 1585.72, "text": "you"}, {"end": 1586.48, "start": 1585.96, "text": "answered"}, {"end": 1586.72, "start": 1586.48, "text": "the"}, {"end": 1586.92, "start": 1586.72, "text": "first"}, {"end": 1587.32, "start": 1586.92, "text": "question,"}, {"end": 1587.32, "start": 1587.32, "text": "you"}, {"end": 1587.56, "start": 1587.32, "text": "get"}, {"end": 1587.56, "start": 1587.56, "text": "a"}, {"end": 1588.0, "start": 1587.56, "text": "cushion."}, {"end": 1588.6, "start": 1588.0, "text": "This"}, {"end": 1588.6, "start": 1588.6, "text": "is"}, {"end": 1588.88, "start": 1588.6, "text": "kind"}, {"end": 1588.96, "start": 1588.88, "text": "of"}, {"end": 1589.08, "start": 1588.96, "text": "like"}, {"end": 1589.24, "start": 1589.08, "text": "a"}, {"end": 1589.96, "start": 1589.24, "text": "Frisbee,"}], "text": " And so, and then the other thing that we realized was that these seats you're sitting on, this is a nice classroom, but the seats you're sitting on are kind of hard. So what Eric and I did was we decided we'll help you guys out, especially the ones who are interacting with us. And we have these cushions that are 6.006 cushions. And that's a two by two by two Rubik's cube here. And since you answered the first question, you get a cushion. This is kind of like a Frisbee,"}, {"chunks": [{"end": 1590.4, "start": 1590.0, "text": "Not"}, {"end": 1590.84, "start": 1590.4, "text": "really."}, {"end": 1591.0, "start": 1590.84, "text": "So"}, {"end": 1591.52, "start": 1591.0, "text": "I'm"}, {"end": 1592.28, "start": 1591.52, "text": "not"}, {"end": 1592.96, "start": 1592.28, "text": "sure"}, {"end": 1593.6, "start": 1592.96, "text": "I'm"}, {"end": 1594.28, "start": 1593.6, "text": "going"}, {"end": 1594.56, "start": 1594.28, "text": "to"}, {"end": 1594.6, "start": 1594.56, "text": "get"}, {"end": 1594.64, "start": 1594.6, "text": "it"}, {"end": 1594.88, "start": 1594.64, "text": "to"}, {"end": 1594.92, "start": 1594.88, "text": "you."}, {"end": 1594.92, "start": 1594.92, "text": "But"}, {"end": 1595.16, "start": 1594.92, "text": "the"}, {"end": 1595.48, "start": 1595.16, "text": "other"}, {"end": 1595.64, "start": 1595.48, "text": "thing"}, {"end": 1595.92, "start": 1595.64, "text": "I"}, {"end": 1596.28, "start": 1595.92, "text": "want"}, {"end": 1596.28, "start": 1596.28, "text": "to"}, {"end": 1596.28, "start": 1596.28, "text": "say"}, {"end": 1596.32, "start": 1596.28, "text": "is"}, {"end": 1596.92, "start": 1596.32, "text": "this"}, {"end": 1597.08, "start": 1596.92, "text": "is"}, {"end": 1597.32, "start": 1597.08, "text": "not"}, {"end": 1597.48, "start": 1597.32, "text": "a"}, {"end": 1597.92, "start": 1597.48, "text": "baseball"}, {"end": 1598.2, "start": 1597.92, "text": "game"}, {"end": 1598.72, "start": 1598.2, "text": "where"}, {"end": 1598.88, "start": 1598.72, "text": "you"}, {"end": 1599.08, "start": 1598.88, "text": "just"}, {"end": 1599.44, "start": 1599.08, "text": "grab"}, {"end": 1599.48, "start": 1599.44, "text": "the"}, {"end": 1599.72, "start": 1599.48, "text": "balls"}, {"end": 1599.88, "start": 1599.72, "text": "that"}, {"end": 1600.04, "start": 1599.88, "text": "come"}, {"end": 1600.4, "start": 1600.04, "text": "by."}, {"end": 1600.72, "start": 1600.4, "text": "This"}, {"end": 1601.0, "start": 1600.72, "text": "is"}, {"end": 1601.44, "start": 1601.0, "text": "meant"}, {"end": 1601.72, "start": 1601.44, "text": "for"}, {"end": 1601.84, "start": 1601.72, "text": "him,"}, {"end": 1602.04, "start": 1601.84, "text": "my"}, {"end": 1602.4, "start": 1602.04, "text": "friend"}, {"end": 1602.4, "start": 1602.4, "text": "in"}, {"end": 1602.76, "start": 1602.4, "text": "the"}, {"end": 1602.96, "start": 1602.76, "text": "red"}, {"end": 1603.64, "start": 1602.96, "text": "shirt."}, {"end": 1603.8, "start": 1603.64, "text": "So"}, {"end": 1604.24, "start": 1603.8, "text": "here"}, {"end": 1604.56, "start": 1604.24, "text": "you"}, {"end": 1605.36, "start": 1604.56, "text": "go."}, {"end": 1605.6, "start": 1605.36, "text": "Ah,"}, {"end": 1605.88, "start": 1605.6, "text": "too"}, {"end": 1606.32, "start": 1605.88, "text": "bad."}, {"end": 1606.72, "start": 1606.32, "text": "All"}, {"end": 1607.32, "start": 1606.72, "text": "right."}, {"end": 1607.48, "start": 1607.32, "text": "It"}, {"end": 1608.0, "start": 1607.48, "text": "is"}, {"end": 1608.56, "start": 1608.0, "text": "soft."}, {"end": 1609.52, "start": 1608.56, "text": "So"}, {"end": 1609.92, "start": 1609.52, "text": "it"}, {"end": 1610.64, "start": 1609.92, "text": "won't"}, {"end": 1610.96, "start": 1610.64, "text": "hurt"}, {"end": 1611.08, "start": 1610.96, "text": "you"}, {"end": 1611.08, "start": 1611.08, "text": "if"}, {"end": 1611.08, "start": 1611.08, "text": "it"}, {"end": 1611.48, "start": 1611.08, "text": "hits"}, {"end": 1611.64, "start": 1611.48, "text": "you."}, {"end": 1611.8, "start": 1611.64, "text": "All"}, {"end": 1612.52, "start": 1611.8, "text": "right?"}, {"end": 1613.28, "start": 1612.52, "text": "So"}, {"end": 1614.0, "start": 1613.28, "text": "if"}, {"end": 1614.12, "start": 1614.0, "text": "you've"}, {"end": 1614.16, "start": 1614.12, "text": "got"}, {"end": 1614.84, "start": 1614.16, "text": "a"}, {"end": 1615.88, "start": 1614.84, "text": "bunch"}, {"end": 1616.44, "start": 1615.88, "text": "of"}, {"end": 1617.08, "start": 1616.44, "text": "these,"}, {"end": 1618.12, "start": 1617.08, "text": "raise"}, {"end": 1619.12, "start": 1618.12, "text": "your"}, {"end": 1619.96, "start": 1619.12, "text": "hands."}], "text": " Not really. So I'm not sure I'm going to get it to you. But the other thing I want to say is this is not a baseball game where you just grab the balls that come by. This is meant for him, my friend in the red shirt. So here you go. Ah, too bad. All right. It is soft. So it won't hurt you if it hits you. All right? So if you've got a bunch of these, raise your hands."}, {"chunks": [{"end": 1620.0, "start": 1620.0, "text": "I"}, {"end": 1620.0, "start": 1620.0, "text": "think"}, {"end": 1620.12, "start": 1620.0, "text": "there's"}, {"end": 1620.48, "start": 1620.12, "text": "some"}, {"end": 1620.56, "start": 1620.48, "text": "trivial"}, {"end": 1620.56, "start": 1620.56, "text": "questions"}, {"end": 1620.84, "start": 1620.56, "text": "that"}, {"end": 1621.16, "start": 1620.84, "text": "we're"}, {"end": 1621.36, "start": 1621.16, "text": "going"}, {"end": 1621.72, "start": 1621.36, "text": "to"}, {"end": 1622.08, "start": 1621.72, "text": "ask"}, {"end": 1622.88, "start": 1622.08, "text": "just"}, {"end": 1623.16, "start": 1622.88, "text": "to"}, {"end": 1623.32, "start": 1623.16, "text": "make"}, {"end": 1624.56, "start": 1623.32, "text": "sure"}, {"end": 1625.28, "start": 1624.56, "text": "you're"}, {"end": 1625.64, "start": 1625.28, "text": "awake."}, {"end": 1626.0, "start": 1625.64, "text": "So"}, {"end": 1626.32, "start": 1626.0, "text": "an"}, {"end": 1626.84, "start": 1626.32, "text": "answer"}, {"end": 1626.84, "start": 1626.84, "text": "to"}, {"end": 1626.84, "start": 1626.84, "text": "that"}, {"end": 1626.92, "start": 1626.84, "text": "doesn't"}, {"end": 1627.12, "start": 1626.92, "text": "get"}, {"end": 1627.56, "start": 1627.12, "text": "you"}, {"end": 1627.68, "start": 1627.56, "text": "a"}, {"end": 1627.72, "start": 1627.68, "text": "cushion."}, {"end": 1628.16, "start": 1627.72, "text": "But"}, {"end": 1628.6, "start": 1628.16, "text": "an"}, {"end": 1629.28, "start": 1628.6, "text": "answer"}, {"end": 1629.8, "start": 1629.28, "text": "like,"}, {"end": 1630.0, "start": 1629.8, "text": "what's"}, {"end": 1630.2, "start": 1630.0, "text": "your"}, {"end": 1630.68, "start": 1630.2, "text": "name?"}, {"end": 1631.16, "start": 1630.68, "text": "Jace."}, {"end": 1631.64, "start": 1631.16, "text": "Jace."}, {"end": 1631.84, "start": 1631.64, "text": "An"}, {"end": 1632.24, "start": 1631.84, "text": "answer"}, {"end": 1632.44, "start": 1632.24, "text": "like"}, {"end": 1632.72, "start": 1632.44, "text": "Jace"}, {"end": 1632.92, "start": 1632.72, "text": "just"}, {"end": 1633.44, "start": 1632.92, "text": "gave"}, {"end": 1633.64, "start": 1633.44, "text": "is,"}, {"end": 1634.44, "start": 1633.64, "text": "that's"}, {"end": 1634.8, "start": 1634.44, "text": "a"}, {"end": 1635.2, "start": 1634.8, "text": "good"}, {"end": 1635.4, "start": 1635.2, "text": "answer"}, {"end": 1635.44, "start": 1635.4, "text": "to"}, {"end": 1635.92, "start": 1635.44, "text": "a"}, {"end": 1636.6, "start": 1635.92, "text": "non-trivial"}, {"end": 1637.04, "start": 1636.6, "text": "question"}, {"end": 1637.24, "start": 1637.04, "text": "that"}, {"end": 1637.44, "start": 1637.24, "text": "gets"}, {"end": 1637.64, "start": 1637.44, "text": "you"}, {"end": 1637.88, "start": 1637.64, "text": "a"}, {"end": 1638.44, "start": 1637.88, "text": "cushion."}, {"end": 1639.28, "start": 1638.44, "text": "OK?"}, {"end": 1639.6, "start": 1639.28, "text": "All"}, {"end": 1639.96, "start": 1639.6, "text": "right,"}, {"end": 1640.28, "start": 1639.96, "text": "great."}, {"end": 1641.24, "start": 1640.28, "text": "So"}, {"end": 1641.84, "start": 1641.24, "text": "let's"}, {"end": 1642.2, "start": 1641.84, "text": "put"}, {"end": 1642.44, "start": 1642.2, "text": "up"}, {"end": 1643.04, "start": 1642.44, "text": "Jace's"}, {"end": 1643.36, "start": 1643.04, "text": "algorithm"}, {"end": 1643.36, "start": 1643.36, "text": "up"}, {"end": 1643.96, "start": 1643.36, "text": "here."}, {"end": 1644.12, "start": 1643.96, "text": "I'm"}, {"end": 1645.24, "start": 1644.12, "text": "going"}, {"end": 1645.68, "start": 1645.24, "text": "to"}, {"end": 1646.28, "start": 1645.68, "text": "write"}, {"end": 1646.68, "start": 1646.28, "text": "it"}, {"end": 1646.88, "start": 1646.68, "text": "out"}, {"end": 1648.36, "start": 1646.88, "text": "for"}, {"end": 1648.64, "start": 1648.36, "text": "the"}, {"end": 1648.92, "start": 1648.64, "text": "1D"}, {"end": 1649.96, "start": 1648.92, "text": "version."}], "text": " I think there's some trivial questions that we're going to ask just to make sure you're awake. So an answer to that doesn't get you a cushion. But an answer like, what's your name? Jace. Jace. An answer like Jace just gave is, that's a good answer to a non-trivial question that gets you a cushion. OK? All right, great. So let's put up Jace's algorithm up here. I'm going to write it out for the 1D version."}, {"chunks": [{"end": 1657.16, "start": 1650.0, "text": "So"}, {"end": 1659.92, "start": 1657.16, "text": "what"}, {"end": 1661.36, "start": 1659.92, "text": "we"}, {"end": 1662.0, "start": 1661.36, "text": "have"}, {"end": 1662.4, "start": 1662.0, "text": "here"}, {"end": 1663.92, "start": 1662.4, "text": "is"}, {"end": 1664.36, "start": 1663.92, "text": "a"}, {"end": 1664.84, "start": 1664.36, "text": "recursive"}, {"end": 1679.96, "start": 1664.84, "text": "algorithm."}], "text": " So what we have here is a recursive algorithm."}, {"chunks": [{"end": 1681.64, "start": 1680.0, "text": "So"}, {"end": 1681.88, "start": 1681.64, "text": "the"}, {"end": 1682.32, "start": 1681.88, "text": "picture"}, {"end": 1682.32, "start": 1682.32, "text": "you"}, {"end": 1683.28, "start": 1682.32, "text": "want"}, {"end": 1683.52, "start": 1683.28, "text": "to"}, {"end": 1683.6, "start": 1683.52, "text": "keep"}, {"end": 1683.68, "start": 1683.6, "text": "in"}, {"end": 1684.24, "start": 1683.68, "text": "your"}, {"end": 1684.76, "start": 1684.24, "text": "head"}, {"end": 1684.88, "start": 1684.76, "text": "is"}, {"end": 1685.08, "start": 1684.88, "text": "this"}, {"end": 1685.8, "start": 1685.08, "text": "picture"}, {"end": 1686.08, "start": 1685.8, "text": "that"}, {"end": 1686.48, "start": 1686.08, "text": "I've"}, {"end": 1686.6, "start": 1686.48, "text": "put"}, {"end": 1686.8, "start": 1686.6, "text": "up"}, {"end": 1687.28, "start": 1686.8, "text": "there."}, {"end": 1687.32, "start": 1687.28, "text": "And"}, {"end": 1687.6, "start": 1687.32, "text": "this"}, {"end": 1688.0, "start": 1687.6, "text": "is"}, {"end": 1688.08, "start": 1688.0, "text": "a"}, {"end": 1688.6, "start": 1688.08, "text": "divide"}, {"end": 1689.4, "start": 1688.6, "text": "and"}, {"end": 1689.52, "start": 1689.4, "text": "conquer"}, {"end": 1690.16, "start": 1689.52, "text": "algorithm."}, {"end": 1690.28, "start": 1690.16, "text": "You're"}, {"end": 1690.36, "start": 1690.28, "text": "going"}, {"end": 1690.92, "start": 1690.36, "text": "to"}, {"end": 1691.24, "start": 1690.92, "text": "see"}, {"end": 1692.08, "start": 1691.24, "text": "this"}, {"end": 1692.24, "start": 1692.08, "text": "over"}, {"end": 1692.56, "start": 1692.24, "text": "and"}, {"end": 1692.92, "start": 1692.56, "text": "over,"}, {"end": 1693.04, "start": 1692.92, "text": "this"}, {"end": 1694.08, "start": 1693.04, "text": "paradigm,"}, {"end": 1694.68, "start": 1694.08, "text": "over"}, {"end": 1695.16, "start": 1694.68, "text": "and"}, {"end": 1695.44, "start": 1695.16, "text": "over"}, {"end": 1695.52, "start": 1695.44, "text": "in"}, {"end": 1697.36, "start": 1695.52, "text": "6006."}, {"end": 1698.32, "start": 1697.36, "text": "We're"}, {"end": 1698.52, "start": 1698.32, "text": "going"}, {"end": 1699.92, "start": 1698.52, "text": "to"}, {"end": 1700.8, "start": 1699.92, "text": "look"}, {"end": 1701.16, "start": 1700.8, "text": "at"}, {"end": 1701.48, "start": 1701.16, "text": "the"}, {"end": 1701.68, "start": 1701.48, "text": "n"}, {"end": 1702.04, "start": 1701.68, "text": "over"}, {"end": 1702.36, "start": 1702.04, "text": "2"}, {"end": 1703.12, "start": 1702.36, "text": "position."}, {"end": 1703.28, "start": 1703.12, "text": "And"}, {"end": 1703.32, "start": 1703.28, "text": "we're"}, {"end": 1703.72, "start": 1703.32, "text": "going"}, {"end": 1704.0, "start": 1703.72, "text": "to"}, {"end": 1704.28, "start": 1704.0, "text": "look"}, {"end": 1704.64, "start": 1704.28, "text": "to"}, {"end": 1705.92, "start": 1704.64, "text": "the"}, {"end": 1706.6, "start": 1705.92, "text": "left,"}, {"end": 1706.72, "start": 1706.6, "text": "and"}, {"end": 1707.12, "start": 1706.72, "text": "we're"}, {"end": 1707.44, "start": 1707.12, "text": "going"}, {"end": 1707.64, "start": 1707.44, "text": "to"}, {"end": 1708.24, "start": 1707.64, "text": "look"}, {"end": 1708.8, "start": 1708.24, "text": "to"}, {"end": 1709.24, "start": 1708.8, "text": "the"}, {"end": 1709.96, "start": 1709.24, "text": "right."}], "text": " So the picture you want to keep in your head is this picture that I've put up there. And this is a divide and conquer algorithm. You're going to see this over and over, this paradigm, over and over in 6006. We're going to look at the n over 2 position. And we're going to look to the left, and we're going to look to the right."}, {"chunks": [{"end": 1710.0, "start": 1710.0, "text": "And"}, {"end": 1710.0, "start": 1710.0, "text": "we're"}, {"end": 1710.0, "start": 1710.0, "text": "going"}, {"end": 1710.6, "start": 1710.0, "text": "to"}, {"end": 1710.72, "start": 1710.6, "text": "do"}, {"end": 1710.88, "start": 1710.72, "text": "that"}, {"end": 1711.64, "start": 1710.88, "text": "in"}, {"end": 1713.52, "start": 1711.64, "text": "sequence."}, {"end": 1716.68, "start": 1713.52, "text": "So"}, {"end": 1717.16, "start": 1716.68, "text": "if"}, {"end": 1717.72, "start": 1717.16, "text": "a"}, {"end": 1718.08, "start": 1717.72, "text": "n"}, {"end": 1718.72, "start": 1718.08, "text": "over"}, {"end": 1720.48, "start": 1718.72, "text": "2"}, {"end": 1720.76, "start": 1720.48, "text": "is"}, {"end": 1721.04, "start": 1720.76, "text": "less"}, {"end": 1722.4, "start": 1721.04, "text": "than"}, {"end": 1722.72, "start": 1722.4, "text": "a"}, {"end": 1723.16, "start": 1722.72, "text": "n"}, {"end": 1723.52, "start": 1723.16, "text": "over"}, {"end": 1723.84, "start": 1723.52, "text": "2"}, {"end": 1724.2, "start": 1723.84, "text": "minus"}, {"end": 1726.16, "start": 1724.2, "text": "1,"}, {"end": 1727.88, "start": 1726.16, "text": "then"}, {"end": 1730.72, "start": 1727.88, "text": "only"}, {"end": 1731.28, "start": 1730.72, "text": "look"}, {"end": 1733.68, "start": 1731.28, "text": "at"}, {"end": 1735.36, "start": 1733.68, "text": "left"}, {"end": 1737.6, "start": 1735.36, "text": "half,"}, {"end": 1738.08, "start": 1737.6, "text": "1"}, {"end": 1738.56, "start": 1738.08, "text": "through"}, {"end": 1738.96, "start": 1738.56, "text": "n"}, {"end": 1739.28, "start": 1738.96, "text": "over"}, {"end": 1739.64, "start": 1739.28, "text": "2"}, {"end": 1739.68, "start": 1739.64, "text": "minus"}, {"end": 1739.96, "start": 1739.68, "text": "1."}], "text": " And we're going to do that in sequence. So if a n over 2 is less than a n over 2 minus 1, then only look at left half, 1 through n over 2 minus 1."}, {"chunks": [{"end": 1740.44, "start": 1740.0, "text": "to"}, {"end": 1740.72, "start": 1740.44, "text": "look"}, {"end": 1741.28, "start": 1740.72, "text": "for"}, {"end": 1741.52, "start": 1741.28, "text": "a"}, {"end": 1741.92, "start": 1741.52, "text": "peak,"}, {"end": 1742.2, "start": 1741.92, "text": "for"}, {"end": 1742.36, "start": 1742.2, "text": "a"}, {"end": 1742.84, "start": 1742.36, "text": "peak."}, {"end": 1743.2, "start": 1742.84, "text": "So"}, {"end": 1743.64, "start": 1743.2, "text": "that's"}, {"end": 1744.64, "start": 1743.64, "text": "step"}, {"end": 1745.16, "start": 1744.64, "text": "one."}, {"end": 1745.44, "start": 1745.16, "text": "And"}, {"end": 1745.64, "start": 1745.44, "text": "I"}, {"end": 1746.48, "start": 1745.64, "text": "could"}, {"end": 1747.16, "start": 1746.48, "text": "have"}, {"end": 1748.6, "start": 1747.16, "text": "done"}, {"end": 1748.96, "start": 1748.6, "text": "the"}, {"end": 1749.72, "start": 1748.96, "text": "right"}, {"end": 1750.4, "start": 1749.72, "text": "hand"}, {"end": 1750.84, "start": 1750.4, "text": "side"}, {"end": 1751.16, "start": 1750.84, "text": "or"}, {"end": 1751.72, "start": 1751.16, "text": "the"}, {"end": 1752.12, "start": 1751.72, "text": "left"}, {"end": 1752.88, "start": 1752.12, "text": "hand"}, {"end": 1753.2, "start": 1752.88, "text": "side."}, {"end": 1753.24, "start": 1753.2, "text": "It"}, {"end": 1753.6, "start": 1753.24, "text": "doesn't"}, {"end": 1754.12, "start": 1753.6, "text": "really"}, {"end": 1755.96, "start": 1754.12, "text": "matter."}, {"end": 1756.04, "start": 1755.96, "text": "I"}, {"end": 1756.44, "start": 1756.04, "text": "chose"}, {"end": 1756.44, "start": 1756.44, "text": "to"}, {"end": 1756.44, "start": 1756.44, "text": "do"}, {"end": 1756.6, "start": 1756.44, "text": "the"}, {"end": 1756.8, "start": 1756.6, "text": "left"}, {"end": 1756.96, "start": 1756.8, "text": "hand"}, {"end": 1757.32, "start": 1756.96, "text": "side"}, {"end": 1757.88, "start": 1757.32, "text": "first,"}, {"end": 1758.52, "start": 1757.88, "text": "the"}, {"end": 1758.72, "start": 1758.52, "text": "left"}, {"end": 1760.24, "start": 1758.72, "text": "half."}, {"end": 1760.68, "start": 1760.24, "text": "And"}, {"end": 1761.0, "start": 1760.68, "text": "so"}, {"end": 1761.08, "start": 1761.0, "text": "what"}, {"end": 1761.64, "start": 1761.08, "text": "I've"}, {"end": 1762.2, "start": 1761.64, "text": "done"}, {"end": 1762.76, "start": 1762.2, "text": "is,"}, {"end": 1762.88, "start": 1762.76, "text": "through"}, {"end": 1763.44, "start": 1762.88, "text": "that"}, {"end": 1763.96, "start": 1763.44, "text": "one"}, {"end": 1764.56, "start": 1763.96, "text": "step,"}, {"end": 1764.92, "start": 1764.56, "text": "if,"}, {"end": 1765.08, "start": 1764.92, "text": "in"}, {"end": 1765.56, "start": 1765.08, "text": "fact,"}, {"end": 1766.64, "start": 1765.56, "text": "you"}, {"end": 1767.48, "start": 1766.64, "text": "have"}, {"end": 1767.96, "start": 1767.48, "text": "that"}, {"end": 1768.6, "start": 1767.96, "text": "condition"}, {"end": 1769.04, "start": 1768.6, "text": "a"}, {"end": 1769.12, "start": 1769.04, "text": "n"}, {"end": 1769.12, "start": 1769.12, "text": "over"}, {"end": 1769.96, "start": 1769.12, "text": "2,"}], "text": " to look for a peak, for a peak. So that's step one. And I could have done the right hand side or the left hand side. It doesn't really matter. I chose to do the left hand side first, the left half. And so what I've done is, through that one step, if, in fact, you have that condition a n over 2,"}, {"chunks": [{"end": 1770.16, "start": 1770.0, "text": "is"}, {"end": 1770.36, "start": 1770.16, "text": "less"}, {"end": 1770.48, "start": 1770.36, "text": "than"}, {"end": 1770.8, "start": 1770.48, "text": "a"}, {"end": 1770.96, "start": 1770.8, "text": "n"}, {"end": 1770.96, "start": 1770.96, "text": "over"}, {"end": 1771.04, "start": 1770.96, "text": "2"}, {"end": 1771.4, "start": 1771.04, "text": "minus"}, {"end": 1772.32, "start": 1771.4, "text": "1,"}, {"end": 1772.68, "start": 1772.32, "text": "then"}, {"end": 1772.68, "start": 1772.68, "text": "you"}, {"end": 1772.72, "start": 1772.68, "text": "move"}, {"end": 1772.84, "start": 1772.72, "text": "to"}, {"end": 1773.12, "start": 1772.84, "text": "your"}, {"end": 1773.56, "start": 1773.12, "text": "left"}, {"end": 1773.6, "start": 1773.56, "text": "and"}, {"end": 1774.0, "start": 1773.6, "text": "you"}, {"end": 1774.48, "start": 1774.0, "text": "work"}, {"end": 1775.28, "start": 1774.48, "text": "on"}, {"end": 1775.52, "start": 1775.28, "text": "1"}, {"end": 1775.96, "start": 1775.52, "text": "half"}, {"end": 1775.96, "start": 1775.96, "text": "of"}, {"end": 1775.96, "start": 1775.96, "text": "the"}, {"end": 1776.56, "start": 1775.96, "text": "problem."}, {"end": 1776.76, "start": 1776.56, "text": "But"}, {"end": 1776.88, "start": 1776.76, "text": "if"}, {"end": 1777.48, "start": 1776.88, "text": "that's"}, {"end": 1777.84, "start": 1777.48, "text": "not"}, {"end": 1778.16, "start": 1777.84, "text": "the"}, {"end": 1779.24, "start": 1778.16, "text": "case,"}, {"end": 1779.72, "start": 1779.24, "text": "then"}, {"end": 1781.28, "start": 1779.72, "text": "if"}, {"end": 1782.48, "start": 1781.28, "text": "n"}, {"end": 1782.8, "start": 1782.48, "text": "over"}, {"end": 1783.04, "start": 1782.8, "text": "2"}, {"end": 1783.28, "start": 1783.04, "text": "is"}, {"end": 1783.6, "start": 1783.28, "text": "less"}, {"end": 1785.0, "start": 1783.6, "text": "than"}, {"end": 1785.32, "start": 1785.0, "text": "a"}, {"end": 1786.04, "start": 1785.32, "text": "over"}, {"end": 1786.16, "start": 1786.04, "text": "n"}, {"end": 1786.4, "start": 1786.16, "text": "by"}, {"end": 1786.72, "start": 1786.4, "text": "2"}, {"end": 1787.0, "start": 1786.72, "text": "plus"}, {"end": 1788.12, "start": 1787.0, "text": "1,"}, {"end": 1788.72, "start": 1788.12, "text": "then"}, {"end": 1789.2, "start": 1788.72, "text": "only"}, {"end": 1789.4, "start": 1789.2, "text": "look"}, {"end": 1789.56, "start": 1789.4, "text": "at"}, {"end": 1789.84, "start": 1789.56, "text": "n"}, {"end": 1790.28, "start": 1789.84, "text": "over"}, {"end": 1790.8, "start": 1790.28, "text": "2"}, {"end": 1792.12, "start": 1790.8, "text": "plus"}, {"end": 1792.88, "start": 1792.12, "text": "1"}, {"end": 1793.12, "start": 1792.88, "text": "through"}, {"end": 1793.12, "start": 1793.12, "text": "n"}, {"end": 1793.56, "start": 1793.12, "text": "for"}, {"end": 1793.8, "start": 1793.56, "text": "a"}, {"end": 1794.12, "start": 1793.8, "text": "peak."}, {"end": 1794.68, "start": 1794.12, "text": "So"}, {"end": 1795.64, "start": 1794.68, "text": "I"}, {"end": 1795.84, "start": 1795.64, "text": "haven't"}, {"end": 1796.12, "start": 1795.84, "text": "bothered"}, {"end": 1796.84, "start": 1796.12, "text": "writing"}, {"end": 1797.32, "start": 1796.84, "text": "out"}, {"end": 1797.52, "start": 1797.32, "text": "all"}, {"end": 1798.84, "start": 1797.52, "text": "the"}, {"end": 1799.96, "start": 1798.84, "text": "words."}], "text": " is less than a n over 2 minus 1, then you move to your left and you work on 1 half of the problem. But if that's not the case, then if n over 2 is less than a over n by 2 plus 1, then only look at n over 2 plus 1 through n for a peak. So I haven't bothered writing out all the words."}, {"chunks": [{"end": 1800.28, "start": 1800.0, "text": "They're"}, {"end": 1800.72, "start": 1800.28, "text": "exactly"}, {"end": 1801.2, "start": 1800.72, "text": "the"}, {"end": 1801.32, "start": 1801.2, "text": "same"}, {"end": 1802.24, "start": 1801.32, "text": "as"}, {"end": 1802.44, "start": 1802.24, "text": "the"}, {"end": 1803.04, "start": 1802.44, "text": "left-hand"}, {"end": 1803.48, "start": 1803.04, "text": "side."}, {"end": 1803.56, "start": 1803.48, "text": "You"}, {"end": 1803.68, "start": 1803.56, "text": "just"}, {"end": 1803.84, "start": 1803.68, "text": "look"}, {"end": 1803.88, "start": 1803.84, "text": "to"}, {"end": 1804.08, "start": 1803.88, "text": "the"}, {"end": 1805.32, "start": 1804.08, "text": "right-hand"}, {"end": 1806.08, "start": 1805.32, "text": "side."}, {"end": 1807.32, "start": 1806.08, "text": "Otherwise,"}, {"end": 1807.48, "start": 1807.32, "text": "if"}, {"end": 1807.6, "start": 1807.48, "text": "both"}, {"end": 1807.8, "start": 1807.6, "text": "of"}, {"end": 1808.16, "start": 1807.8, "text": "these"}, {"end": 1808.76, "start": 1808.16, "text": "conditions"}, {"end": 1809.04, "start": 1808.76, "text": "don't"}, {"end": 1810.04, "start": 1809.04, "text": "fire,"}, {"end": 1810.52, "start": 1810.04, "text": "you're"}, {"end": 1810.88, "start": 1810.52, "text": "actually"}, {"end": 1812.16, "start": 1810.88, "text": "done."}, {"end": 1812.6, "start": 1812.16, "text": "OK?"}, {"end": 1812.8, "start": 1812.6, "text": "That's"}, {"end": 1813.08, "start": 1812.8, "text": "actually"}, {"end": 1813.12, "start": 1813.08, "text": "the"}, {"end": 1813.32, "start": 1813.12, "text": "best"}, {"end": 1813.68, "start": 1813.32, "text": "case"}, {"end": 1813.72, "start": 1813.68, "text": "in"}, {"end": 1814.16, "start": 1813.72, "text": "terms"}, {"end": 1814.68, "start": 1814.16, "text": "of"}, {"end": 1815.08, "start": 1814.68, "text": "finishing"}, {"end": 1815.4, "start": 1815.08, "text": "early,"}, {"end": 1816.12, "start": 1815.4, "text": "at"}, {"end": 1816.48, "start": 1816.12, "text": "least"}, {"end": 1816.48, "start": 1816.48, "text": "in"}, {"end": 1816.76, "start": 1816.48, "text": "this"}, {"end": 1817.12, "start": 1816.76, "text": "recursive"}, {"end": 1818.32, "start": 1817.12, "text": "step."}, {"end": 1818.56, "start": 1818.32, "text": "Because"}, {"end": 1819.4, "start": 1818.56, "text": "now"}, {"end": 1819.4, "start": 1819.4, "text": "the"}, {"end": 1819.4, "start": 1819.4, "text": "n"}, {"end": 1819.4, "start": 1819.4, "text": "over"}, {"end": 1819.6, "start": 1819.4, "text": "2"}, {"end": 1821.96, "start": 1819.6, "text": "position"}, {"end": 1822.24, "start": 1821.96, "text": "is"}, {"end": 1822.4, "start": 1822.24, "text": "a"}, {"end": 1822.68, "start": 1822.4, "text": "peak."}, {"end": 1824.16, "start": 1822.68, "text": "Because"}, {"end": 1824.68, "start": 1824.16, "text": "what"}, {"end": 1825.84, "start": 1824.68, "text": "you've"}, {"end": 1827.16, "start": 1825.84, "text": "found"}, {"end": 1827.52, "start": 1827.16, "text": "is"}, {"end": 1828.4, "start": 1827.52, "text": "that"}, {"end": 1828.76, "start": 1828.4, "text": "the"}, {"end": 1829.44, "start": 1828.76, "text": "n"}, {"end": 1829.76, "start": 1829.44, "text": "over"}, {"end": 1829.96, "start": 1829.76, "text": "2"}], "text": " They're exactly the same as the left-hand side. You just look to the right-hand side. Otherwise, if both of these conditions don't fire, you're actually done. OK? That's actually the best case in terms of finishing early, at least in this recursive step. Because now the n over 2 position is a peak. Because what you've found is that the n over 2"}, {"chunks": [{"end": 1830.44, "start": 1830.0, "text": "position"}, {"end": 1830.88, "start": 1830.44, "text": "is"}, {"end": 1831.12, "start": 1830.88, "text": "greater"}, {"end": 1831.64, "start": 1831.12, "text": "than"}, {"end": 1831.76, "start": 1831.64, "text": "or"}, {"end": 1831.76, "start": 1831.76, "text": "equal"}, {"end": 1832.44, "start": 1831.76, "text": "to"}, {"end": 1832.6, "start": 1832.44, "text": "both"}, {"end": 1832.76, "start": 1832.6, "text": "of"}, {"end": 1833.4, "start": 1832.76, "text": "its"}, {"end": 1833.84, "start": 1833.4, "text": "adjacent"}, {"end": 1834.24, "start": 1833.84, "text": "positions."}, {"end": 1834.24, "start": 1834.24, "text": "And"}, {"end": 1834.84, "start": 1834.24, "text": "that's"}, {"end": 1835.44, "start": 1834.84, "text": "exactly"}, {"end": 1835.6, "start": 1835.44, "text": "the"}, {"end": 1836.0, "start": 1835.6, "text": "definition"}, {"end": 1836.12, "start": 1836.0, "text": "of"}, {"end": 1836.24, "start": 1836.12, "text": "a"}, {"end": 1836.84, "start": 1836.24, "text": "peak."}, {"end": 1837.32, "start": 1836.84, "text": "So"}, {"end": 1838.36, "start": 1837.32, "text": "you're"}, {"end": 1838.44, "start": 1838.36, "text": "done."}, {"end": 1839.32, "start": 1838.44, "text": "OK?"}, {"end": 1840.88, "start": 1839.32, "text": "So"}, {"end": 1841.44, "start": 1840.88, "text": "all"}, {"end": 1841.64, "start": 1841.44, "text": "of"}, {"end": 1841.84, "start": 1841.64, "text": "this"}, {"end": 1842.0, "start": 1841.84, "text": "is"}, {"end": 1843.92, "start": 1842.0, "text": "good."}, {"end": 1844.48, "start": 1843.92, "text": "You"}, {"end": 1845.2, "start": 1844.48, "text": "want"}, {"end": 1845.84, "start": 1845.2, "text": "to"}, {"end": 1846.36, "start": 1845.84, "text": "write"}, {"end": 1846.72, "start": 1846.36, "text": "an"}, {"end": 1848.48, "start": 1846.72, "text": "argument"}, {"end": 1849.08, "start": 1848.48, "text": "that"}, {"end": 1850.24, "start": 1849.08, "text": "this"}, {"end": 1850.84, "start": 1850.24, "text": "algorithm"}, {"end": 1850.84, "start": 1850.84, "text": "is"}, {"end": 1851.48, "start": 1850.84, "text": "correct."}, {"end": 1852.08, "start": 1851.48, "text": "And"}, {"end": 1852.64, "start": 1852.08, "text": "I'm"}, {"end": 1853.0, "start": 1852.64, "text": "not"}, {"end": 1853.16, "start": 1853.0, "text": "going"}, {"end": 1853.44, "start": 1853.16, "text": "to"}, {"end": 1854.32, "start": 1853.44, "text": "bother"}, {"end": 1854.32, "start": 1854.32, "text": "with"}, {"end": 1854.88, "start": 1854.32, "text": "that."}, {"end": 1855.04, "start": 1854.88, "text": "I"}, {"end": 1856.2, "start": 1855.04, "text": "just"}, {"end": 1856.6, "start": 1856.2, "text": "waved"}, {"end": 1857.08, "start": 1856.6, "text": "my"}, {"end": 1857.44, "start": 1857.08, "text": "hands"}, {"end": 1857.72, "start": 1857.44, "text": "a"}, {"end": 1857.84, "start": 1857.72, "text": "bit."}, {"end": 1857.92, "start": 1857.84, "text": "And"}, {"end": 1858.2, "start": 1857.92, "text": "you"}, {"end": 1858.36, "start": 1858.2, "text": "all"}, {"end": 1858.84, "start": 1858.36, "text": "nodded,"}, {"end": 1859.24, "start": 1858.84, "text": "so"}, {"end": 1859.48, "start": 1859.24, "text": "we're"}, {"end": 1859.96, "start": 1859.48, "text": "done."}], "text": " position is greater than or equal to both of its adjacent positions. And that's exactly the definition of a peak. So you're done. OK? So all of this is good. You want to write an argument that this algorithm is correct. And I'm not going to bother with that. I just waved my hands a bit. And you all nodded, so we're done."}, {"chunks": [{"end": 1861.0, "start": 1860.0, "text": "that,"}, {"end": 1862.36, "start": 1861.0, "text": "but"}, {"end": 1862.52, "start": 1862.36, "text": "the"}, {"end": 1862.84, "start": 1862.52, "text": "point"}, {"end": 1863.08, "start": 1862.84, "text": "being,"}, {"end": 1863.56, "start": 1863.08, "text": "you"}, {"end": 1864.16, "start": 1863.56, "text": "will"}, {"end": 1865.04, "start": 1864.16, "text": "see"}, {"end": 1865.52, "start": 1865.04, "text": "in"}, {"end": 1865.96, "start": 1865.52, "text": "your"}, {"end": 1866.32, "start": 1865.96, "text": "problem"}, {"end": 1867.16, "start": 1866.32, "text": "set"}, {"end": 1867.36, "start": 1867.16, "text": "a"}, {"end": 1868.64, "start": 1867.36, "text": "precise"}, {"end": 1869.32, "start": 1868.64, "text": "argument"}, {"end": 1869.48, "start": 1869.32, "text": "for"}, {"end": 1869.52, "start": 1869.48, "text": "a"}, {"end": 1869.88, "start": 1869.52, "text": "more"}, {"end": 1870.52, "start": 1869.88, "text": "complicated"}, {"end": 1870.96, "start": 1870.52, "text": "algorithm,"}, {"end": 1871.2, "start": 1870.96, "text": "the"}, {"end": 1871.52, "start": 1871.2, "text": "2D"}, {"end": 1871.92, "start": 1871.52, "text": "version"}, {"end": 1871.92, "start": 1871.92, "text": "of"}, {"end": 1872.72, "start": 1871.92, "text": "this."}, {"end": 1873.08, "start": 1872.72, "text": "And"}, {"end": 1873.52, "start": 1873.08, "text": "that"}, {"end": 1873.64, "start": 1873.52, "text": "should"}, {"end": 1873.84, "start": 1873.64, "text": "be"}, {"end": 1873.84, "start": 1873.84, "text": "a"}, {"end": 1874.36, "start": 1873.84, "text": "template"}, {"end": 1874.52, "start": 1874.36, "text": "for"}, {"end": 1874.96, "start": 1874.52, "text": "you"}, {"end": 1875.08, "start": 1874.96, "text": "to"}, {"end": 1875.16, "start": 1875.08, "text": "go"}, {"end": 1876.04, "start": 1875.16, "text": "write"}, {"end": 1876.32, "start": 1876.04, "text": "a"}, {"end": 1876.8, "start": 1876.32, "text": "proof"}, {"end": 1876.8, "start": 1876.8, "text": "or"}, {"end": 1876.88, "start": 1876.8, "text": "an"}, {"end": 1877.64, "start": 1876.88, "text": "argument,"}, {"end": 1877.92, "start": 1877.64, "text": "a"}, {"end": 1878.12, "start": 1877.92, "text": "formal"}, {"end": 1879.2, "start": 1878.12, "text": "argument,"}, {"end": 1879.72, "start": 1879.2, "text": "that"}, {"end": 1879.76, "start": 1879.72, "text": "a"}, {"end": 1880.12, "start": 1879.76, "text": "particular"}, {"end": 1880.56, "start": 1880.12, "text": "algorithm"}, {"end": 1880.8, "start": 1880.56, "text": "is"}, {"end": 1880.8, "start": 1880.8, "text": "correct,"}, {"end": 1881.6, "start": 1880.8, "text": "that"}, {"end": 1881.76, "start": 1881.6, "text": "it"}, {"end": 1882.08, "start": 1881.76, "text": "does"}, {"end": 1882.28, "start": 1882.08, "text": "what"}, {"end": 1882.32, "start": 1882.28, "text": "it"}, {"end": 1882.76, "start": 1882.32, "text": "claims"}, {"end": 1883.52, "start": 1882.76, "text": "to"}, {"end": 1884.72, "start": 1883.52, "text": "do."}, {"end": 1885.12, "start": 1884.72, "text": "And"}, {"end": 1885.32, "start": 1885.12, "text": "in"}, {"end": 1885.64, "start": 1885.32, "text": "this"}, {"end": 1886.56, "start": 1885.64, "text": "case,"}, {"end": 1886.8, "start": 1886.56, "text": "it's"}, {"end": 1887.28, "start": 1886.8, "text": "two,"}, {"end": 1887.68, "start": 1887.28, "text": "three"}, {"end": 1888.36, "start": 1887.68, "text": "lines"}, {"end": 1888.6, "start": 1888.36, "text": "of"}, {"end": 1889.12, "start": 1888.6, "text": "careful"}, {"end": 1889.96, "start": 1889.12, "text": "reasoning."}], "text": " that, but the point being, you will see in your problem set a precise argument for a more complicated algorithm, the 2D version of this. And that should be a template for you to go write a proof or an argument, a formal argument, that a particular algorithm is correct, that it does what it claims to do. And in this case, it's two, three lines of careful reasoning."}, {"chunks": [{"end": 1891.32, "start": 1890.0, "text": "That"}, {"end": 1891.76, "start": 1891.32, "text": "essentially"}, {"end": 1892.16, "start": 1891.76, "text": "say,"}, {"end": 1892.52, "start": 1892.16, "text": "given"}, {"end": 1892.96, "start": 1892.52, "text": "the"}, {"end": 1893.32, "start": 1892.96, "text": "definition"}, {"end": 1893.44, "start": 1893.32, "text": "of"}, {"end": 1893.48, "start": 1893.44, "text": "the"}, {"end": 1894.52, "start": 1893.48, "text": "peak,"}, {"end": 1895.04, "start": 1894.52, "text": "that"}, {"end": 1895.52, "start": 1895.04, "text": "this"}, {"end": 1895.6, "start": 1895.52, "text": "is"}, {"end": 1896.08, "start": 1895.6, "text": "going"}, {"end": 1896.08, "start": 1896.08, "text": "to"}, {"end": 1896.12, "start": 1896.08, "text": "find"}, {"end": 1896.32, "start": 1896.12, "text": "a"}, {"end": 1896.44, "start": 1896.32, "text": "peak"}, {"end": 1897.2, "start": 1896.44, "text": "in"}, {"end": 1897.4, "start": 1897.2, "text": "the"}, {"end": 1897.68, "start": 1897.4, "text": "array"}, {"end": 1898.24, "start": 1897.68, "text": "that"}, {"end": 1898.68, "start": 1898.24, "text": "you're"}, {"end": 1898.84, "start": 1898.68, "text": "given."}, {"end": 1899.84, "start": 1898.84, "text": "All"}, {"end": 1900.88, "start": 1899.84, "text": "right?"}, {"end": 1901.4, "start": 1900.88, "text": "So"}, {"end": 1901.4, "start": 1901.4, "text": "we"}, {"end": 1901.52, "start": 1901.4, "text": "all"}, {"end": 1901.8, "start": 1901.52, "text": "believe"}, {"end": 1901.88, "start": 1901.8, "text": "that"}, {"end": 1902.04, "start": 1901.88, "text": "this"}, {"end": 1903.12, "start": 1902.04, "text": "algorithm"}, {"end": 1903.36, "start": 1903.12, "text": "is"}, {"end": 1903.96, "start": 1903.36, "text": "correct."}, {"end": 1904.32, "start": 1903.96, "text": "Let's"}, {"end": 1905.6, "start": 1904.32, "text": "talk"}, {"end": 1905.96, "start": 1905.6, "text": "now"}, {"end": 1906.04, "start": 1905.96, "text": "about"}, {"end": 1906.12, "start": 1906.04, "text": "the"}, {"end": 1906.72, "start": 1906.12, "text": "complexity"}, {"end": 1906.72, "start": 1906.72, "text": "of"}, {"end": 1906.72, "start": 1906.72, "text": "this"}, {"end": 1907.16, "start": 1906.72, "text": "algorithm."}, {"end": 1907.16, "start": 1907.16, "text": "Because"}, {"end": 1907.16, "start": 1907.16, "text": "the"}, {"end": 1907.2, "start": 1907.16, "text": "whole"}, {"end": 1908.36, "start": 1907.2, "text": "point"}, {"end": 1908.64, "start": 1908.36, "text": "of"}, {"end": 1908.88, "start": 1908.64, "text": "this"}, {"end": 1909.92, "start": 1908.88, "text": "algorithm"}, {"end": 1910.16, "start": 1909.92, "text": "was"}, {"end": 1910.64, "start": 1910.16, "text": "because"}, {"end": 1910.64, "start": 1910.64, "text": "we"}, {"end": 1911.0, "start": 1910.64, "text": "didn't"}, {"end": 1911.6, "start": 1911.0, "text": "like"}, {"end": 1912.36, "start": 1911.6, "text": "this"}, {"end": 1912.68, "start": 1912.36, "text": "theta"}, {"end": 1913.04, "start": 1912.68, "text": "n"}, {"end": 1914.04, "start": 1913.04, "text": "complexity"}, {"end": 1914.76, "start": 1914.04, "text": "corresponding"}, {"end": 1914.76, "start": 1914.76, "text": "to"}, {"end": 1914.92, "start": 1914.76, "text": "the"}, {"end": 1915.44, "start": 1914.92, "text": "straightforward"}, {"end": 1916.32, "start": 1915.44, "text": "algorithm."}, {"end": 1916.64, "start": 1916.32, "text": "So"}, {"end": 1916.76, "start": 1916.64, "text": "we'd"}, {"end": 1917.0, "start": 1916.76, "text": "like"}, {"end": 1917.12, "start": 1917.0, "text": "to"}, {"end": 1917.12, "start": 1917.12, "text": "do"}, {"end": 1919.96, "start": 1917.12, "text": "better."}], "text": " That essentially say, given the definition of the peak, that this is going to find a peak in the array that you're given. All right? So we all believe that this algorithm is correct. Let's talk now about the complexity of this algorithm. Because the whole point of this algorithm was because we didn't like this theta n complexity corresponding to the straightforward algorithm. So we'd like to do better."}, {"chunks": [{"end": 1921.92, "start": 1920.0, "text": "So"}, {"end": 1928.44, "start": 1921.92, "text": "what"}, {"end": 1929.08, "start": 1928.44, "text": "I'd"}, {"end": 1929.4, "start": 1929.08, "text": "like"}, {"end": 1929.4, "start": 1929.4, "text": "to"}, {"end": 1929.4, "start": 1929.4, "text": "do"}, {"end": 1929.52, "start": 1929.4, "text": "is"}, {"end": 1930.36, "start": 1929.52, "text": "ask"}, {"end": 1930.44, "start": 1930.36, "text": "one"}, {"end": 1930.64, "start": 1930.44, "text": "of"}, {"end": 1930.76, "start": 1930.64, "text": "you"}, {"end": 1930.92, "start": 1930.76, "text": "to"}, {"end": 1931.0, "start": 1930.92, "text": "give"}, {"end": 1931.56, "start": 1931.0, "text": "me"}, {"end": 1931.68, "start": 1931.56, "text": "a"}, {"end": 1932.28, "start": 1931.68, "text": "recurrence"}, {"end": 1933.36, "start": 1932.28, "text": "relation"}, {"end": 1933.44, "start": 1933.36, "text": "of"}, {"end": 1933.56, "start": 1933.44, "text": "the"}, {"end": 1934.28, "start": 1933.56, "text": "kind"}, {"end": 1934.96, "start": 1934.28, "text": "t"}, {"end": 1934.96, "start": 1934.96, "text": "of"}, {"end": 1934.96, "start": 1934.96, "text": "n"}, {"end": 1935.92, "start": 1934.96, "text": "equals"}, {"end": 1936.16, "start": 1935.92, "text": "blah,"}, {"end": 1936.32, "start": 1936.16, "text": "blah,"}, {"end": 1937.8, "start": 1936.32, "text": "blah"}, {"end": 1938.56, "start": 1937.8, "text": "that"}, {"end": 1938.76, "start": 1938.56, "text": "would"}, {"end": 1939.36, "start": 1938.76, "text": "correspond"}, {"end": 1939.88, "start": 1939.36, "text": "to"}, {"end": 1941.4, "start": 1939.88, "text": "this"}, {"end": 1941.84, "start": 1941.4, "text": "recursive"}, {"end": 1942.24, "start": 1941.84, "text": "algorithm,"}, {"end": 1942.6, "start": 1942.24, "text": "this"}, {"end": 1942.92, "start": 1942.6, "text": "divide"}, {"end": 1942.96, "start": 1942.92, "text": "and"}, {"end": 1943.24, "start": 1942.96, "text": "conquer"}, {"end": 1943.6, "start": 1943.24, "text": "algorithm."}, {"end": 1944.0, "start": 1943.6, "text": "And"}, {"end": 1944.28, "start": 1944.0, "text": "then"}, {"end": 1944.6, "start": 1944.28, "text": "using"}, {"end": 1945.56, "start": 1944.6, "text": "that,"}, {"end": 1945.72, "start": 1945.56, "text": "I'd"}, {"end": 1945.96, "start": 1945.72, "text": "like"}, {"end": 1946.36, "start": 1945.96, "text": "to"}, {"end": 1946.6, "start": 1946.36, "text": "get"}, {"end": 1947.64, "start": 1946.6, "text": "to"}, {"end": 1948.08, "start": 1947.64, "text": "the"}, {"end": 1948.56, "start": 1948.08, "text": "actual"}, {"end": 1949.08, "start": 1948.56, "text": "complexity"}, {"end": 1949.08, "start": 1949.08, "text": "in"}, {"end": 1949.36, "start": 1949.08, "text": "terms"}, {"end": 1949.8, "start": 1949.36, "text": "of"}, {"end": 1949.96, "start": 1949.8, "text": "what"}], "text": " So what I'd like to do is ask one of you to give me a recurrence relation of the kind t of n equals blah, blah, blah that would correspond to this recursive algorithm, this divide and conquer algorithm. And then using that, I'd like to get to the actual complexity in terms of what"}, {"chunks": [{"end": 1950.16, "start": 1950.0, "text": "the"}, {"end": 1950.68, "start": 1950.16, "text": "theta"}, {"end": 1951.08, "start": 1950.68, "text": "of"}, {"end": 1951.76, "start": 1951.08, "text": "complexity"}, {"end": 1952.32, "start": 1951.76, "text": "corresponds"}, {"end": 1953.48, "start": 1952.32, "text": "to."}, {"end": 1953.76, "start": 1953.48, "text": "Yeah,"}, {"end": 1953.88, "start": 1953.76, "text": "back"}, {"end": 1955.08, "start": 1953.88, "text": "there."}, {"end": 1955.52, "start": 1955.08, "text": "So"}, {"end": 1955.64, "start": 1955.52, "text": "in"}, {"end": 1956.24, "start": 1955.64, "text": "the"}, {"end": 1956.48, "start": 1956.24, "text": "worst"}, {"end": 1956.68, "start": 1956.48, "text": "case"}, {"end": 1957.76, "start": 1956.68, "text": "scenario,"}, {"end": 1957.92, "start": 1957.76, "text": "the"}, {"end": 1958.24, "start": 1957.92, "text": "t"}, {"end": 1958.52, "start": 1958.24, "text": "of"}, {"end": 1959.24, "start": 1958.52, "text": "n"}, {"end": 1959.44, "start": 1959.24, "text": "is"}, {"end": 1959.56, "start": 1959.44, "text": "going"}, {"end": 1959.72, "start": 1959.56, "text": "to"}, {"end": 1960.96, "start": 1959.72, "text": "be"}, {"end": 1961.24, "start": 1960.96, "text": "some"}, {"end": 1961.84, "start": 1961.24, "text": "constant"}, {"end": 1962.2, "start": 1961.84, "text": "amount"}, {"end": 1962.56, "start": 1962.2, "text": "of"}, {"end": 1963.28, "start": 1962.56, "text": "time"}, {"end": 1963.48, "start": 1963.28, "text": "it"}, {"end": 1965.0, "start": 1963.48, "text": "takes"}, {"end": 1965.36, "start": 1965.0, "text": "to"}, {"end": 1966.28, "start": 1965.36, "text": "investigate"}, {"end": 1966.56, "start": 1966.28, "text": "whether"}, {"end": 1966.84, "start": 1966.56, "text": "a"}, {"end": 1967.72, "start": 1966.84, "text": "certain"}, {"end": 1968.0, "start": 1967.72, "text": "element"}, {"end": 1968.08, "start": 1968.0, "text": "is"}, {"end": 1968.64, "start": 1968.08, "text": "t"}, {"end": 1969.48, "start": 1968.64, "text": "plus"}, {"end": 1970.0, "start": 1969.48, "text": "t"}, {"end": 1970.08, "start": 1970.0, "text": "of"}, {"end": 1970.8, "start": 1970.08, "text": "n"}, {"end": 1971.24, "start": 1970.8, "text": "over"}, {"end": 1971.56, "start": 1971.24, "text": "2."}, {"end": 1971.72, "start": 1971.56, "text": "Great."}, {"end": 1972.04, "start": 1971.72, "text": "Exactly"}, {"end": 1972.12, "start": 1972.04, "text": "right."}, {"end": 1972.48, "start": 1972.12, "text": "That's"}, {"end": 1973.56, "start": 1972.48, "text": "exactly"}, {"end": 1974.44, "start": 1973.56, "text": "right."}, {"end": 1975.24, "start": 1974.44, "text": "So"}, {"end": 1975.32, "start": 1975.24, "text": "if"}, {"end": 1975.6, "start": 1975.32, "text": "you"}, {"end": 1975.6, "start": 1975.6, "text": "look"}, {"end": 1975.6, "start": 1975.6, "text": "at"}, {"end": 1975.96, "start": 1975.6, "text": "this"}, {"end": 1976.88, "start": 1975.96, "text": "algorithm"}, {"end": 1977.2, "start": 1976.88, "text": "and"}, {"end": 1977.28, "start": 1977.2, "text": "you"}, {"end": 1978.32, "start": 1977.28, "text": "say"}, {"end": 1978.84, "start": 1978.32, "text": "from"}, {"end": 1978.88, "start": 1978.84, "text": "a"}, {"end": 1979.96, "start": 1978.88, "text": "computation"}], "text": " the theta of complexity corresponds to. Yeah, back there. So in the worst case scenario, the t of n is going to be some constant amount of time it takes to investigate whether a certain element is t plus t of n over 2. Great. Exactly right. That's exactly right. So if you look at this algorithm and you say from a computation"}, {"chunks": [{"end": 1980.04, "start": 1980.0, "text": "standpoint,"}, {"end": 1980.36, "start": 1980.04, "text": "can"}, {"end": 1981.08, "start": 1980.36, "text": "I"}, {"end": 1982.52, "start": 1981.08, "text": "write"}, {"end": 1983.04, "start": 1982.52, "text": "an"}, {"end": 1984.08, "start": 1983.04, "text": "equation"}, {"end": 1984.68, "start": 1984.08, "text": "corresponding"}, {"end": 1984.88, "start": 1984.68, "text": "to"}, {"end": 1985.0, "start": 1984.88, "text": "the"}, {"end": 1985.76, "start": 1985.0, "text": "execution"}, {"end": 1986.52, "start": 1985.76, "text": "of"}, {"end": 1987.2, "start": 1986.52, "text": "this"}, {"end": 1988.04, "start": 1987.2, "text": "algorithm,"}, {"end": 1988.72, "start": 1988.04, "text": "and"}, {"end": 1988.72, "start": 1988.72, "text": "you"}, {"end": 1989.36, "start": 1988.72, "text": "say"}, {"end": 1990.04, "start": 1989.36, "text": "t"}, {"end": 1990.92, "start": 1990.04, "text": "of"}, {"end": 1991.32, "start": 1990.92, "text": "n"}, {"end": 1991.56, "start": 1991.32, "text": "is"}, {"end": 1991.6, "start": 1991.56, "text": "the"}, {"end": 1991.76, "start": 1991.6, "text": "work"}, {"end": 1992.36, "start": 1991.76, "text": "that"}, {"end": 1992.56, "start": 1992.36, "text": "this"}, {"end": 1993.76, "start": 1992.56, "text": "algorithm"}, {"end": 1994.52, "start": 1993.76, "text": "does"}, {"end": 1995.04, "start": 1994.52, "text": "on"}, {"end": 1998.36, "start": 1995.04, "text": "input"}, {"end": 2003.24, "start": 1998.36, "text": "of"}, {"end": 2005.4, "start": 2003.24, "text": "size"}, {"end": 2005.8, "start": 2005.4, "text": "n,"}, {"end": 2006.0, "start": 2005.8, "text": "then"}, {"end": 2006.52, "start": 2006.0, "text": "I"}, {"end": 2007.12, "start": 2006.52, "text": "can"}, {"end": 2007.92, "start": 2007.12, "text": "write"}, {"end": 2008.28, "start": 2007.92, "text": "this"}, {"end": 2009.96, "start": 2008.28, "text": "equation."}], "text": " standpoint, can I write an equation corresponding to the execution of this algorithm, and you say t of n is the work that this algorithm does on input of size n, then I can write this equation."}, {"chunks": [{"end": 2011.0, "start": 2010.0, "text": "And"}, {"end": 2011.24, "start": 2011.0, "text": "this"}, {"end": 2011.6, "start": 2011.24, "text": "theta"}, {"end": 2011.92, "start": 2011.6, "text": "1"}, {"end": 2013.28, "start": 2011.92, "text": "corresponds"}, {"end": 2013.44, "start": 2013.28, "text": "to"}, {"end": 2013.48, "start": 2013.44, "text": "the"}, {"end": 2013.84, "start": 2013.48, "text": "two"}, {"end": 2014.48, "start": 2013.84, "text": "comparisons"}, {"end": 2014.8, "start": 2014.48, "text": "that"}, {"end": 2015.36, "start": 2014.8, "text": "you"}, {"end": 2015.52, "start": 2015.36, "text": "do"}, {"end": 2015.96, "start": 2015.52, "text": "looking"}, {"end": 2016.52, "start": 2015.96, "text": "at,"}, {"end": 2017.16, "start": 2016.52, "text": "potentially,"}, {"end": 2017.28, "start": 2017.16, "text": "the"}, {"end": 2017.28, "start": 2017.28, "text": "two"}, {"end": 2017.64, "start": 2017.28, "text": "comparisons"}, {"end": 2017.96, "start": 2017.64, "text": "that"}, {"end": 2018.24, "start": 2017.96, "text": "you"}, {"end": 2018.24, "start": 2018.24, "text": "do"}, {"end": 2018.4, "start": 2018.24, "text": "looking"}, {"end": 2018.44, "start": 2018.4, "text": "at"}, {"end": 2018.68, "start": 2018.44, "text": "the"}, {"end": 2019.08, "start": 2018.68, "text": "left"}, {"end": 2019.2, "start": 2019.08, "text": "hand"}, {"end": 2019.6, "start": 2019.2, "text": "side"}, {"end": 2020.2, "start": 2019.6, "text": "and"}, {"end": 2020.64, "start": 2020.2, "text": "the"}, {"end": 2021.0, "start": 2020.64, "text": "right"}, {"end": 2021.44, "start": 2021.0, "text": "hand"}, {"end": 2021.72, "start": 2021.44, "text": "side."}, {"end": 2021.84, "start": 2021.72, "text": "So"}, {"end": 2021.96, "start": 2021.84, "text": "that's"}, {"end": 2022.0, "start": 2021.96, "text": "a"}, {"end": 2022.04, "start": 2022.0, "text": "2"}, {"end": 2022.04, "start": 2022.04, "text": "is"}, {"end": 2022.04, "start": 2022.04, "text": "a"}, {"end": 2022.32, "start": 2022.04, "text": "constant."}, {"end": 2022.32, "start": 2022.32, "text": "So"}, {"end": 2022.88, "start": 2022.32, "text": "that's"}, {"end": 2023.32, "start": 2022.88, "text": "why"}, {"end": 2023.48, "start": 2023.32, "text": "we"}, {"end": 2023.48, "start": 2023.48, "text": "put"}, {"end": 2023.52, "start": 2023.48, "text": "theta"}, {"end": 2023.8, "start": 2023.52, "text": "1."}, {"end": 2024.56, "start": 2023.8, "text": "All"}, {"end": 2024.96, "start": 2024.56, "text": "right?"}, {"end": 2025.16, "start": 2024.96, "text": "So"}, {"end": 2025.16, "start": 2025.16, "text": "you"}, {"end": 2025.28, "start": 2025.16, "text": "get"}, {"end": 2025.6, "start": 2025.28, "text": "a"}, {"end": 2025.88, "start": 2025.6, "text": "cushion"}, {"end": 2026.12, "start": 2025.88, "text": "too."}, {"end": 2026.84, "start": 2026.12, "text": "Watch"}, {"end": 2027.36, "start": 2026.84, "text": "out,"}, {"end": 2029.6, "start": 2027.36, "text": "guys."}, {"end": 2030.76, "start": 2029.6, "text": "Whoa."}, {"end": 2031.24, "start": 2030.76, "text": "Actually,"}, {"end": 2031.64, "start": 2031.24, "text": "that"}, {"end": 2032.04, "start": 2031.64, "text": "wasn't"}, {"end": 2032.36, "start": 2032.04, "text": "so"}, {"end": 2033.28, "start": 2032.36, "text": "bad."}, {"end": 2033.88, "start": 2033.28, "text": "All"}, {"end": 2034.04, "start": 2033.88, "text": "right."}, {"end": 2034.4, "start": 2034.04, "text": "Wears"}, {"end": 2035.24, "start": 2034.4, "text": "left."}, {"end": 2035.64, "start": 2035.24, "text": "Eric,"}, {"end": 2037.04, "start": 2035.64, "text": "Wears"}, {"end": 2037.4, "start": 2037.04, "text": "left."}, {"end": 2037.96, "start": 2037.4, "text": "So"}, {"end": 2038.0, "start": 2037.96, "text": "if"}, {"end": 2038.0, "start": 2038.0, "text": "you"}, {"end": 2038.2, "start": 2038.0, "text": "take"}, {"end": 2038.84, "start": 2038.2, "text": "this"}, {"end": 2039.16, "start": 2038.84, "text": "and"}, {"end": 2039.68, "start": 2039.16, "text": "you"}, {"end": 2039.96, "start": 2039.68, "text": "start"}], "text": " And this theta 1 corresponds to the two comparisons that you do looking at, potentially, the two comparisons that you do looking at the left hand side and the right hand side. So that's a 2 is a constant. So that's why we put theta 1. All right? So you get a cushion too. Watch out, guys. Whoa. Actually, that wasn't so bad. All right. Wears left. Eric, Wears left. So if you take this and you start"}, {"chunks": [{"end": 2042.12, "start": 2040.0, "text": "are"}, {"end": 2042.84, "start": 2042.12, "text": "expanding"}, {"end": 2043.36, "start": 2042.84, "text": "it,"}, {"end": 2044.04, "start": 2043.36, "text": "eventually"}, {"end": 2044.24, "start": 2044.04, "text": "you're"}, {"end": 2044.44, "start": 2044.24, "text": "going"}, {"end": 2044.44, "start": 2044.44, "text": "to"}, {"end": 2044.44, "start": 2044.44, "text": "get"}, {"end": 2044.64, "start": 2044.44, "text": "to"}, {"end": 2044.84, "start": 2044.64, "text": "the"}, {"end": 2045.12, "start": 2044.84, "text": "base"}, {"end": 2046.24, "start": 2045.12, "text": "case,"}, {"end": 2046.48, "start": 2046.24, "text": "which"}, {"end": 2047.08, "start": 2046.48, "text": "is"}, {"end": 2047.84, "start": 2047.08, "text": "t"}, {"end": 2048.76, "start": 2047.84, "text": "of"}, {"end": 2048.96, "start": 2048.76, "text": "1"}, {"end": 2048.96, "start": 2048.96, "text": "is"}, {"end": 2049.12, "start": 2048.96, "text": "theta"}, {"end": 2049.28, "start": 2049.12, "text": "1."}, {"end": 2049.64, "start": 2049.28, "text": "Because"}, {"end": 2049.96, "start": 2049.64, "text": "you"}, {"end": 2050.4, "start": 2049.96, "text": "have"}, {"end": 2050.56, "start": 2050.4, "text": "a"}, {"end": 2050.76, "start": 2050.56, "text": "one"}, {"end": 2051.0, "start": 2050.76, "text": "element"}, {"end": 2051.04, "start": 2051.0, "text": "array,"}, {"end": 2051.84, "start": 2051.04, "text": "for"}, {"end": 2052.44, "start": 2051.84, "text": "that"}, {"end": 2052.72, "start": 2052.44, "text": "array,"}, {"end": 2053.52, "start": 2052.72, "text": "you're"}, {"end": 2054.24, "start": 2053.52, "text": "just"}, {"end": 2054.8, "start": 2054.24, "text": "going"}, {"end": 2055.4, "start": 2054.8, "text": "to"}, {"end": 2056.0, "start": 2055.4, "text": "return"}, {"end": 2056.48, "start": 2056.0, "text": "that"}, {"end": 2056.96, "start": 2056.48, "text": "as"}, {"end": 2057.16, "start": 2056.96, "text": "a"}, {"end": 2057.2, "start": 2057.16, "text": "peak."}, {"end": 2057.64, "start": 2057.2, "text": "And"}, {"end": 2057.88, "start": 2057.64, "text": "so"}, {"end": 2058.2, "start": 2057.88, "text": "if"}, {"end": 2058.36, "start": 2058.2, "text": "you"}, {"end": 2059.12, "start": 2058.36, "text": "do"}, {"end": 2059.64, "start": 2059.12, "text": "that"}, {"end": 2060.24, "start": 2059.64, "text": "and"}, {"end": 2060.48, "start": 2060.24, "text": "you"}, {"end": 2062.2, "start": 2060.48, "text": "expand"}, {"end": 2062.92, "start": 2062.2, "text": "it"}, {"end": 2063.6, "start": 2062.92, "text": "all"}, {"end": 2063.92, "start": 2063.6, "text": "the"}, {"end": 2064.56, "start": 2063.92, "text": "way"}, {"end": 2064.84, "start": 2064.56, "text": "out,"}, {"end": 2065.32, "start": 2064.84, "text": "then"}, {"end": 2065.44, "start": 2065.32, "text": "you"}, {"end": 2065.52, "start": 2065.44, "text": "can"}, {"end": 2066.2, "start": 2065.52, "text": "write"}, {"end": 2066.24, "start": 2066.2, "text": "t"}, {"end": 2066.4, "start": 2066.24, "text": "of"}, {"end": 2067.2, "start": 2066.4, "text": "n"}, {"end": 2067.4, "start": 2067.2, "text": "equals"}, {"end": 2067.64, "start": 2067.4, "text": "theta"}, {"end": 2068.0, "start": 2067.64, "text": "1"}, {"end": 2069.4, "start": 2068.0, "text": "plus"}, {"end": 2069.96, "start": 2069.4, "text": "theta"}], "text": " are expanding it, eventually you're going to get to the base case, which is t of 1 is theta 1. Because you have a one element array, for that array, you're just going to return that as a peak. And so if you do that and you expand it all the way out, then you can write t of n equals theta 1 plus theta"}, {"chunks": [{"end": 2070.44, "start": 2070.0, "text": "theta"}, {"end": 2070.44, "start": 2070.44, "text": "1,"}, {"end": 2071.12, "start": 2070.44, "text": "and"}, {"end": 2071.28, "start": 2071.12, "text": "you're"}, {"end": 2071.56, "start": 2071.28, "text": "going"}, {"end": 2071.76, "start": 2071.56, "text": "to"}, {"end": 2071.76, "start": 2071.76, "text": "do"}, {"end": 2073.36, "start": 2071.76, "text": "this"}, {"end": 2074.0, "start": 2073.36, "text": "log"}, {"end": 2075.12, "start": 2074.0, "text": "to"}, {"end": 2075.32, "start": 2075.12, "text": "the"}, {"end": 2075.6, "start": 2075.32, "text": "base"}, {"end": 2076.16, "start": 2075.6, "text": "2"}, {"end": 2076.36, "start": 2076.16, "text": "of"}, {"end": 2076.64, "start": 2076.36, "text": "n"}, {"end": 2078.8, "start": 2076.64, "text": "times."}, {"end": 2079.0, "start": 2078.8, "text": "And"}, {"end": 2079.24, "start": 2079.0, "text": "adding"}, {"end": 2079.88, "start": 2079.24, "text": "these"}, {"end": 2082.12, "start": 2079.88, "text": "all"}, {"end": 2083.32, "start": 2082.12, "text": "up"}, {"end": 2083.56, "start": 2083.32, "text": "gives"}, {"end": 2083.76, "start": 2083.56, "text": "you"}, {"end": 2083.84, "start": 2083.76, "text": "a"}, {"end": 2084.88, "start": 2083.84, "text": "complexity"}, {"end": 2085.12, "start": 2084.88, "text": "theta"}, {"end": 2085.36, "start": 2085.12, "text": "log"}, {"end": 2085.64, "start": 2085.36, "text": "2"}, {"end": 2086.32, "start": 2085.64, "text": "of"}, {"end": 2088.32, "start": 2086.32, "text": "n."}, {"end": 2088.72, "start": 2088.32, "text": "So"}, {"end": 2088.88, "start": 2088.72, "text": "now"}, {"end": 2088.88, "start": 2088.88, "text": "you"}, {"end": 2089.76, "start": 2088.88, "text": "compare"}, {"end": 2091.04, "start": 2089.76, "text": "this"}, {"end": 2091.2, "start": 2091.04, "text": "with"}, {"end": 2091.88, "start": 2091.2, "text": "that."}, {"end": 2093.08, "start": 2091.88, "text": "And"}, {"end": 2093.44, "start": 2093.08, "text": "there's"}, {"end": 2093.76, "start": 2093.44, "text": "really"}, {"end": 2093.92, "start": 2093.76, "text": "a"}, {"end": 2094.2, "start": 2093.92, "text": "huge"}, {"end": 2094.6, "start": 2094.2, "text": "difference."}, {"end": 2094.96, "start": 2094.6, "text": "There's"}, {"end": 2095.08, "start": 2094.96, "text": "an"}, {"end": 2095.56, "start": 2095.08, "text": "exponential"}, {"end": 2096.6, "start": 2095.56, "text": "difference."}, {"end": 2097.44, "start": 2096.6, "text": "If"}, {"end": 2097.6, "start": 2097.44, "text": "you"}, {"end": 2098.0, "start": 2097.6, "text": "coded"}, {"end": 2098.0, "start": 2098.0, "text": "up"}, {"end": 2098.72, "start": 2098.0, "text": "this"}, {"end": 2099.52, "start": 2098.72, "text": "algorithm"}, {"end": 2099.96, "start": 2099.52, "text": "in"}], "text": " theta 1, and you're going to do this log to the base 2 of n times. And adding these all up gives you a complexity theta log 2 of n. So now you compare this with that. And there's really a huge difference. There's an exponential difference. If you coded up this algorithm in"}, {"chunks": [{"end": 2101.64, "start": 2100.0, "text": "Python."}, {"end": 2101.88, "start": 2101.64, "text": "And"}, {"end": 2103.04, "start": 2101.88, "text": "I"}, {"end": 2103.52, "start": 2103.04, "text": "did"}, {"end": 2103.76, "start": 2103.52, "text": "both"}, {"end": 2104.16, "start": 2103.76, "text": "these"}, {"end": 2104.52, "start": 2104.16, "text": "algorithms"}, {"end": 2104.64, "start": 2104.52, "text": "for"}, {"end": 2104.68, "start": 2104.64, "text": "the"}, {"end": 2105.04, "start": 2104.68, "text": "1D"}, {"end": 2106.16, "start": 2105.04, "text": "version."}, {"end": 2106.68, "start": 2106.16, "text": "And"}, {"end": 2107.08, "start": 2106.68, "text": "if"}, {"end": 2108.6, "start": 2107.08, "text": "you"}, {"end": 2109.0, "start": 2108.6, "text": "run"}, {"end": 2109.2, "start": 2109.0, "text": "it"}, {"end": 2110.04, "start": 2109.2, "text": "on"}, {"end": 2111.0, "start": 2110.04, "text": "n"}, {"end": 2111.4, "start": 2111.0, "text": "being"}, {"end": 2112.24, "start": 2111.4, "text": "10"}, {"end": 2112.72, "start": 2112.24, "text": "million"}, {"end": 2113.28, "start": 2112.72, "text": "or"}, {"end": 2114.16, "start": 2113.28, "text": "so,"}, {"end": 2114.76, "start": 2114.16, "text": "then"}, {"end": 2115.24, "start": 2114.76, "text": "this"}, {"end": 2115.88, "start": 2115.24, "text": "algorithm"}, {"end": 2116.32, "start": 2115.88, "text": "takes"}, {"end": 2116.76, "start": 2116.32, "text": "13"}, {"end": 2118.0, "start": 2116.76, "text": "seconds."}, {"end": 2118.92, "start": 2118.0, "text": "The"}, {"end": 2119.32, "start": 2118.92, "text": "theta"}, {"end": 2119.68, "start": 2119.32, "text": "n"}, {"end": 2120.08, "start": 2119.68, "text": "algorithm"}, {"end": 2120.32, "start": 2120.08, "text": "takes"}, {"end": 2120.76, "start": 2120.32, "text": "13"}, {"end": 2121.92, "start": 2120.76, "text": "seconds."}, {"end": 2122.0, "start": 2121.92, "text": "And"}, {"end": 2122.16, "start": 2122.0, "text": "this"}, {"end": 2122.36, "start": 2122.16, "text": "one"}, {"end": 2123.8, "start": 2122.36, "text": "takes"}, {"end": 2124.96, "start": 2123.8, "text": "0.001"}, {"end": 2126.2, "start": 2124.96, "text": "seconds."}, {"end": 2126.6, "start": 2126.2, "text": "Huge"}, {"end": 2127.8, "start": 2126.6, "text": "difference."}, {"end": 2128.12, "start": 2127.8, "text": "So"}, {"end": 2128.48, "start": 2128.12, "text": "there"}, {"end": 2128.64, "start": 2128.48, "text": "is"}, {"end": 2128.76, "start": 2128.64, "text": "a"}, {"end": 2128.76, "start": 2128.76, "text": "big"}, {"end": 2129.04, "start": 2128.76, "text": "difference"}, {"end": 2129.24, "start": 2129.04, "text": "between"}, {"end": 2129.32, "start": 2129.24, "text": "theta"}, {"end": 2129.76, "start": 2129.32, "text": "n"}, {"end": 2129.8, "start": 2129.76, "text": "and"}, {"end": 2129.96, "start": 2129.8, "text": "theta"}], "text": " Python. And I did both these algorithms for the 1D version. And if you run it on n being 10 million or so, then this algorithm takes 13 seconds. The theta n algorithm takes 13 seconds. And this one takes 0.001 seconds. Huge difference. So there is a big difference between theta n and theta"}, {"chunks": [{"end": 2131.4, "start": 2130.0, "text": "log"}, {"end": 2131.52, "start": 2131.4, "text": "n."}, {"end": 2131.76, "start": 2131.52, "text": "It's"}, {"end": 2131.88, "start": 2131.76, "text": "literally"}, {"end": 2132.12, "start": 2131.88, "text": "the"}, {"end": 2132.68, "start": 2132.12, "text": "difference"}, {"end": 2133.04, "start": 2132.68, "text": "between"}, {"end": 2133.2, "start": 2133.04, "text": "2"}, {"end": 2133.68, "start": 2133.2, "text": "raised"}, {"end": 2134.0, "start": 2133.68, "text": "to"}, {"end": 2135.04, "start": 2134.0, "text": "n"}, {"end": 2135.84, "start": 2135.04, "text": "and"}, {"end": 2135.84, "start": 2135.84, "text": "n."}, {"end": 2135.92, "start": 2135.84, "text": "It"}, {"end": 2136.12, "start": 2135.92, "text": "makes"}, {"end": 2136.6, "start": 2136.12, "text": "sense"}, {"end": 2136.6, "start": 2136.6, "text": "to"}, {"end": 2138.56, "start": 2136.6, "text": "try"}, {"end": 2139.2, "start": 2138.56, "text": "and"}, {"end": 2139.52, "start": 2139.2, "text": "reduce"}, {"end": 2140.28, "start": 2139.52, "text": "complexity,"}, {"end": 2140.6, "start": 2140.28, "text": "as"}, {"end": 2140.68, "start": 2140.6, "text": "you"}, {"end": 2141.6, "start": 2140.68, "text": "can"}, {"end": 2141.84, "start": 2141.6, "text": "see,"}, {"end": 2142.84, "start": 2141.84, "text": "especially"}, {"end": 2143.12, "start": 2142.84, "text": "if"}, {"end": 2143.4, "start": 2143.12, "text": "you're"}, {"end": 2144.08, "start": 2143.4, "text": "talking"}, {"end": 2145.16, "start": 2144.08, "text": "about"}, {"end": 2145.4, "start": 2145.16, "text": "large"}, {"end": 2145.84, "start": 2145.4, "text": "inputs."}, {"end": 2146.44, "start": 2145.84, "text": "And"}, {"end": 2146.56, "start": 2146.44, "text": "you'll"}, {"end": 2146.72, "start": 2146.56, "text": "see"}, {"end": 2147.0, "start": 2146.72, "text": "that"}, {"end": 2147.48, "start": 2147.0, "text": "more"}, {"end": 2148.48, "start": 2147.48, "text": "clearly"}, {"end": 2148.68, "start": 2148.48, "text": "as"}, {"end": 2148.8, "start": 2148.68, "text": "we"}, {"end": 2149.0, "start": 2148.8, "text": "go"}, {"end": 2149.04, "start": 2149.0, "text": "to"}, {"end": 2149.24, "start": 2149.04, "text": "a"}, {"end": 2149.52, "start": 2149.24, "text": "2D"}, {"end": 2149.92, "start": 2149.52, "text": "version"}, {"end": 2149.92, "start": 2149.92, "text": "of"}, {"end": 2150.08, "start": 2149.92, "text": "this"}, {"end": 2151.2, "start": 2150.08, "text": "problem."}, {"end": 2151.6, "start": 2151.2, "text": "So"}, {"end": 2151.6, "start": 2151.6, "text": "you"}, {"end": 2152.44, "start": 2151.6, "text": "can't"}, {"end": 2152.76, "start": 2152.44, "text": "really"}, {"end": 2152.96, "start": 2152.76, "text": "do"}, {"end": 2153.24, "start": 2152.96, "text": "better"}, {"end": 2153.72, "start": 2153.24, "text": "for"}, {"end": 2153.96, "start": 2153.72, "text": "the"}, {"end": 2154.32, "start": 2153.96, "text": "1D."}, {"end": 2154.56, "start": 2154.32, "text": "The"}, {"end": 2154.6, "start": 2154.56, "text": "1D"}, {"end": 2154.6, "start": 2154.6, "text": "is"}, {"end": 2154.76, "start": 2154.6, "text": "a"}, {"end": 2155.6, "start": 2154.76, "text": "straightforward"}, {"end": 2156.72, "start": 2155.6, "text": "problem."}, {"end": 2156.8, "start": 2156.72, "text": "It"}, {"end": 2157.24, "start": 2156.8, "text": "gets"}, {"end": 2157.48, "start": 2157.24, "text": "a"}, {"end": 2158.48, "start": 2157.48, "text": "little"}, {"end": 2158.8, "start": 2158.48, "text": "more"}, {"end": 2159.96, "start": 2158.8, "text": "interesting."}], "text": " log n. It's literally the difference between 2 raised to n and n. It makes sense to try and reduce complexity, as you can see, especially if you're talking about large inputs. And you'll see that more clearly as we go to a 2D version of this problem. So you can't really do better for the 1D. The 1D is a straightforward problem. It gets a little more interesting."}, {"chunks": [{"end": 2160.04, "start": 2160.0, "text": "Excuse"}, {"end": 2160.12, "start": 2160.04, "text": "me."}, {"end": 2160.52, "start": 2160.12, "text": "The"}, {"end": 2160.68, "start": 2160.52, "text": "algorithms"}, {"end": 2160.8, "start": 2160.68, "text": "get"}, {"end": 2161.04, "start": 2160.8, "text": "a"}, {"end": 2161.72, "start": 2161.04, "text": "little"}, {"end": 2162.36, "start": 2161.72, "text": "more"}, {"end": 2162.76, "start": 2162.36, "text": "sophisticated"}, {"end": 2163.08, "start": 2162.76, "text": "when"}, {"end": 2163.08, "start": 2163.08, "text": "we"}, {"end": 2163.6, "start": 2163.08, "text": "look"}, {"end": 2164.04, "start": 2163.6, "text": "at"}, {"end": 2164.2, "start": 2164.04, "text": "a"}, {"end": 2164.6, "start": 2164.2, "text": "2D"}, {"end": 2165.68, "start": 2164.6, "text": "version"}, {"end": 2166.24, "start": 2165.68, "text": "of"}, {"end": 2166.68, "start": 2166.24, "text": "peak"}, {"end": 2168.32, "start": 2166.68, "text": "finding."}, {"end": 2169.2, "start": 2168.32, "text": "So"}, {"end": 2169.56, "start": 2169.2, "text": "let's"}, {"end": 2169.88, "start": 2169.56, "text": "talk"}, {"end": 2170.92, "start": 2169.88, "text": "about"}, {"end": 2171.4, "start": 2170.92, "text": "the"}, {"end": 2172.36, "start": 2171.4, "text": "2D"}, {"end": 2174.24, "start": 2172.36, "text": "version."}, {"end": 2175.28, "start": 2174.24, "text": "So"}, {"end": 2175.52, "start": 2175.28, "text": "as"}, {"end": 2175.76, "start": 2175.52, "text": "you"}, {"end": 2176.68, "start": 2175.76, "text": "can"}, {"end": 2177.24, "start": 2176.68, "text": "imagine,"}, {"end": 2177.52, "start": 2177.24, "text": "in"}, {"end": 2177.52, "start": 2177.52, "text": "the"}, {"end": 2177.84, "start": 2177.52, "text": "2D"}, {"end": 2178.2, "start": 2177.84, "text": "version,"}, {"end": 2178.8, "start": 2178.2, "text": "you"}, {"end": 2179.08, "start": 2178.8, "text": "have"}, {"end": 2179.2, "start": 2179.08, "text": "a"}, {"end": 2179.2, "start": 2179.2, "text": "matrix"}, {"end": 2179.28, "start": 2179.2, "text": "or"}, {"end": 2179.4, "start": 2179.28, "text": "a"}, {"end": 2180.36, "start": 2179.4, "text": "two-dimensional"}, {"end": 2183.2, "start": 2180.36, "text": "array."}, {"end": 2183.44, "start": 2183.2, "text": "And"}, {"end": 2184.0, "start": 2183.44, "text": "we'll"}, {"end": 2184.6, "start": 2184.0, "text": "say"}, {"end": 2184.88, "start": 2184.6, "text": "this"}, {"end": 2185.2, "start": 2184.88, "text": "thing"}, {"end": 2186.32, "start": 2185.2, "text": "has"}, {"end": 2186.6, "start": 2186.32, "text": "n"}, {"end": 2188.6, "start": 2186.6, "text": "rows"}, {"end": 2188.92, "start": 2188.6, "text": "and"}, {"end": 2189.24, "start": 2188.92, "text": "m"}, {"end": 2189.96, "start": 2189.24, "text": "columns."}], "text": " Excuse me. The algorithms get a little more sophisticated when we look at a 2D version of peak finding. So let's talk about the 2D version. So as you can imagine, in the 2D version, you have a matrix or a two-dimensional array. And we'll say this thing has n rows and m columns."}, {"chunks": [{"end": 2190.4, "start": 2190.0, "text": "And"}, {"end": 2190.56, "start": 2190.4, "text": "now"}, {"end": 2190.84, "start": 2190.56, "text": "we"}, {"end": 2190.96, "start": 2190.84, "text": "have"}, {"end": 2192.0, "start": 2190.96, "text": "to"}, {"end": 2192.48, "start": 2192.0, "text": "define"}, {"end": 2193.04, "start": 2192.48, "text": "what"}, {"end": 2193.28, "start": 2193.04, "text": "a"}, {"end": 2195.16, "start": 2193.28, "text": "peak"}, {"end": 2195.44, "start": 2195.16, "text": "is."}, {"end": 2196.24, "start": 2195.44, "text": "And"}, {"end": 2197.2, "start": 2196.24, "text": "it's"}, {"end": 2197.6, "start": 2197.2, "text": "a"}, {"end": 2198.4, "start": 2197.6, "text": "hill."}, {"end": 2199.08, "start": 2198.4, "text": "It's"}, {"end": 2199.56, "start": 2199.08, "text": "the"}, {"end": 2200.0, "start": 2199.56, "text": "obvious"}, {"end": 2200.64, "start": 2200.0, "text": "definition"}, {"end": 2200.84, "start": 2200.64, "text": "of"}, {"end": 2201.04, "start": 2200.84, "text": "a"}, {"end": 2201.52, "start": 2201.04, "text": "peak."}, {"end": 2202.0, "start": 2201.52, "text": "So"}, {"end": 2202.24, "start": 2202.0, "text": "if"}, {"end": 2202.8, "start": 2202.24, "text": "you"}, {"end": 2203.0, "start": 2202.8, "text": "had"}, {"end": 2203.36, "start": 2203.0, "text": "A"}, {"end": 2203.84, "start": 2203.36, "text": "in"}, {"end": 2205.16, "start": 2203.84, "text": "here,"}, {"end": 2206.76, "start": 2205.16, "text": "C,"}, {"end": 2207.6, "start": 2206.76, "text": "B,"}, {"end": 2208.8, "start": 2207.6, "text": "D,"}, {"end": 2210.36, "start": 2208.8, "text": "E,"}, {"end": 2210.92, "start": 2210.36, "text": "then"}, {"end": 2211.32, "start": 2210.92, "text": "as"}, {"end": 2211.68, "start": 2211.32, "text": "you"}, {"end": 2211.8, "start": 2211.68, "text": "can"}, {"end": 2213.44, "start": 2211.8, "text": "guess,"}, {"end": 2214.96, "start": 2213.44, "text": "A"}, {"end": 2215.2, "start": 2214.96, "text": "is"}, {"end": 2215.44, "start": 2215.2, "text": "a"}, {"end": 2216.6, "start": 2215.44, "text": "2D"}, {"end": 2217.2, "start": 2216.6, "text": "peak"}, {"end": 2218.96, "start": 2217.2, "text": "if"}, {"end": 2219.24, "start": 2218.96, "text": "and"}, {"end": 2219.96, "start": 2219.24, "text": "only"}], "text": " And now we have to define what a peak is. And it's a hill. It's the obvious definition of a peak. So if you had A in here, C, B, D, E, then as you can guess, A is a 2D peak if and only"}, {"chunks": [{"end": 2222.24, "start": 2220.0, "text": "If"}, {"end": 2222.44, "start": 2222.24, "text": "A"}, {"end": 2223.0, "start": 2222.44, "text": "greater"}, {"end": 2223.04, "start": 2223.0, "text": "than"}, {"end": 2223.16, "start": 2223.04, "text": "or"}, {"end": 2223.16, "start": 2223.16, "text": "equal"}, {"end": 2223.36, "start": 2223.16, "text": "to"}, {"end": 2224.52, "start": 2223.36, "text": "B,"}, {"end": 2224.72, "start": 2224.52, "text": "A"}, {"end": 2225.52, "start": 2224.72, "text": "greater"}, {"end": 2226.2, "start": 2225.52, "text": "than"}, {"end": 2226.68, "start": 2226.2, "text": "or"}, {"end": 2226.96, "start": 2226.68, "text": "equal"}, {"end": 2226.96, "start": 2226.96, "text": "to"}, {"end": 2227.16, "start": 2226.96, "text": "D,"}, {"end": 2227.72, "start": 2227.16, "text": "C,"}, {"end": 2228.12, "start": 2227.72, "text": "and"}, {"end": 2228.12, "start": 2228.12, "text": "E."}, {"end": 2228.28, "start": 2228.12, "text": "So"}, {"end": 2228.8, "start": 2228.28, "text": "it's"}, {"end": 2228.96, "start": 2228.8, "text": "a"}, {"end": 2229.0, "start": 2228.96, "text": "little"}, {"end": 2229.36, "start": 2229.0, "text": "hill"}, {"end": 2230.36, "start": 2229.36, "text": "up"}, {"end": 2230.6, "start": 2230.36, "text": "there."}, {"end": 2230.76, "start": 2230.6, "text": "And"}, {"end": 2231.2, "start": 2230.76, "text": "again,"}, {"end": 2231.44, "start": 2231.2, "text": "I've"}, {"end": 2232.44, "start": 2231.44, "text": "used"}, {"end": 2232.68, "start": 2232.44, "text": "the"}, {"end": 2233.4, "start": 2232.68, "text": "greater"}, {"end": 2234.08, "start": 2233.4, "text": "than"}, {"end": 2234.16, "start": 2234.08, "text": "or"}, {"end": 2234.2, "start": 2234.16, "text": "equal"}, {"end": 2234.4, "start": 2234.2, "text": "to"}, {"end": 2235.12, "start": 2234.4, "text": "here."}, {"end": 2235.4, "start": 2235.12, "text": "So"}, {"end": 2236.0, "start": 2235.4, "text": "that's"}, {"end": 2236.24, "start": 2236.0, "text": "similar"}, {"end": 2236.76, "start": 2236.24, "text": "to"}, {"end": 2237.04, "start": 2236.76, "text": "the"}, {"end": 2237.72, "start": 2237.04, "text": "1D"}, {"end": 2237.92, "start": 2237.72, "text": "in"}, {"end": 2238.08, "start": 2237.92, "text": "the"}, {"end": 2238.44, "start": 2238.08, "text": "case"}, {"end": 2238.76, "start": 2238.44, "text": "that"}, {"end": 2239.08, "start": 2238.76, "text": "you'll"}, {"end": 2239.36, "start": 2239.08, "text": "always"}, {"end": 2239.68, "start": 2239.36, "text": "find"}, {"end": 2239.84, "start": 2239.68, "text": "a"}, {"end": 2240.24, "start": 2239.84, "text": "peak"}, {"end": 2240.36, "start": 2240.24, "text": "in"}, {"end": 2240.64, "start": 2240.36, "text": "any"}, {"end": 2241.0, "start": 2240.64, "text": "2D"}, {"end": 2243.92, "start": 2241.0, "text": "matrix."}, {"end": 2245.08, "start": 2243.92, "text": "Now,"}, {"end": 2245.52, "start": 2245.08, "text": "again,"}, {"end": 2246.12, "start": 2245.52, "text": "I'll"}, {"end": 2246.28, "start": 2246.12, "text": "give"}, {"end": 2246.44, "start": 2246.28, "text": "you"}, {"end": 2246.68, "start": 2246.44, "text": "the"}, {"end": 2247.64, "start": 2246.68, "text": "straightforward"}, {"end": 2248.96, "start": 2247.64, "text": "algorithm."}, {"end": 2249.12, "start": 2248.96, "text": "And"}, {"end": 2249.12, "start": 2249.12, "text": "we'll"}, {"end": 2249.32, "start": 2249.12, "text": "call"}, {"end": 2249.44, "start": 2249.32, "text": "it"}, {"end": 2249.96, "start": 2249.44, "text": "the"}], "text": " If A greater than or equal to B, A greater than or equal to D, C, and E. So it's a little hill up there. And again, I've used the greater than or equal to here. So that's similar to the 1D in the case that you'll always find a peak in any 2D matrix. Now, again, I'll give you the straightforward algorithm. And we'll call it the"}, {"chunks": [{"end": 2250.36, "start": 2250.0, "text": "a"}, {"end": 2250.8, "start": 2250.36, "text": "greedy"}, {"end": 2251.32, "start": 2250.8, "text": "ascent"}, {"end": 2259.44, "start": 2251.32, "text": "algorithm."}, {"end": 2259.64, "start": 2259.44, "text": "And"}, {"end": 2261.52, "start": 2259.64, "text": "the"}, {"end": 2261.96, "start": 2261.52, "text": "greedy"}, {"end": 2262.48, "start": 2261.96, "text": "ascent"}, {"end": 2263.28, "start": 2262.48, "text": "algorithm"}, {"end": 2263.8, "start": 2263.28, "text": "essentially"}, {"end": 2264.04, "start": 2263.8, "text": "picks"}, {"end": 2264.16, "start": 2264.04, "text": "a"}, {"end": 2265.6, "start": 2264.16, "text": "direction"}, {"end": 2266.56, "start": 2265.6, "text": "and"}, {"end": 2266.84, "start": 2266.56, "text": "tries"}, {"end": 2266.92, "start": 2266.84, "text": "to"}, {"end": 2267.4, "start": 2266.92, "text": "follow"}, {"end": 2267.44, "start": 2267.4, "text": "that"}, {"end": 2268.36, "start": 2267.44, "text": "direction"}, {"end": 2270.16, "start": 2268.36, "text": "in"}, {"end": 2270.48, "start": 2270.16, "text": "order"}, {"end": 2271.2, "start": 2270.48, "text": "to"}, {"end": 2271.52, "start": 2271.2, "text": "find"}, {"end": 2271.6, "start": 2271.52, "text": "a"}, {"end": 2272.76, "start": 2271.6, "text": "peak."}, {"end": 2273.24, "start": 2272.76, "text": "So"}, {"end": 2274.32, "start": 2273.24, "text": "for"}, {"end": 2274.76, "start": 2274.32, "text": "example,"}, {"end": 2274.92, "start": 2274.76, "text": "if"}, {"end": 2275.16, "start": 2274.92, "text": "I"}, {"end": 2276.48, "start": 2275.16, "text": "had"}, {"end": 2276.72, "start": 2276.48, "text": "this"}, {"end": 2279.96, "start": 2276.72, "text": "particular"}], "text": " a greedy ascent algorithm. And the greedy ascent algorithm essentially picks a direction and tries to follow that direction in order to find a peak. So for example, if I had this particular"}, {"chunks": [{"end": 2282.04, "start": 2280.0, "text": "Matrix"}, {"end": 2283.32, "start": 2282.04, "text": "14,"}, {"end": 2284.32, "start": 2283.32, "text": "13,"}, {"end": 2287.2, "start": 2284.32, "text": "12,"}, {"end": 2287.76, "start": 2287.2, "text": "15,"}, {"end": 2289.04, "start": 2287.76, "text": "9,"}, {"end": 2289.56, "start": 2289.04, "text": "11."}, {"end": 2289.8, "start": 2289.56, "text": "Then"}, {"end": 2290.44, "start": 2289.8, "text": "what"}, {"end": 2291.12, "start": 2290.44, "text": "might"}, {"end": 2292.88, "start": 2291.12, "text": "happen"}, {"end": 2293.12, "start": 2292.88, "text": "is"}, {"end": 2297.2, "start": 2293.12, "text": "if"}, {"end": 2298.24, "start": 2297.2, "text": "I"}, {"end": 2299.16, "start": 2298.24, "text": "started"}, {"end": 2299.28, "start": 2299.16, "text": "at"}, {"end": 2300.24, "start": 2299.28, "text": "some"}, {"end": 2301.04, "start": 2300.24, "text": "arbitrary"}, {"end": 2301.84, "start": 2301.04, "text": "midpoint,"}, {"end": 2302.32, "start": 2301.84, "text": "so"}, {"end": 2302.48, "start": 2302.32, "text": "the"}, {"end": 2302.68, "start": 2302.48, "text": "greedy"}, {"end": 2303.0, "start": 2302.68, "text": "ascent"}, {"end": 2303.36, "start": 2303.0, "text": "algorithm"}, {"end": 2303.56, "start": 2303.36, "text": "has"}, {"end": 2303.56, "start": 2303.56, "text": "to"}, {"end": 2303.68, "start": 2303.56, "text": "make"}, {"end": 2304.6, "start": 2303.68, "text": "choices"}, {"end": 2304.96, "start": 2304.6, "text": "as"}, {"end": 2305.32, "start": 2304.96, "text": "to"}, {"end": 2305.76, "start": 2305.32, "text": "where"}, {"end": 2306.08, "start": 2305.76, "text": "to"}, {"end": 2306.16, "start": 2306.08, "text": "start."}, {"end": 2306.48, "start": 2306.16, "text": "Just"}, {"end": 2307.04, "start": 2306.48, "text": "like"}, {"end": 2307.04, "start": 2307.04, "text": "we"}, {"end": 2307.16, "start": 2307.04, "text": "had"}, {"end": 2307.48, "start": 2307.16, "text": "different"}, {"end": 2307.92, "start": 2307.48, "text": "cases"}, {"end": 2307.96, "start": 2307.92, "text": "here,"}, {"end": 2308.32, "start": 2307.96, "text": "you"}, {"end": 2308.36, "start": 2308.32, "text": "have"}, {"end": 2308.48, "start": 2308.36, "text": "to"}, {"end": 2309.04, "start": 2308.48, "text": "make"}, {"end": 2309.48, "start": 2309.04, "text": "a"}, {"end": 2309.96, "start": 2309.48, "text": "choice"}], "text": " Matrix 14, 13, 12, 15, 9, 11. Then what might happen is if I started at some arbitrary midpoint, so the greedy ascent algorithm has to make choices as to where to start. Just like we had different cases here, you have to make a choice"}, {"chunks": [{"end": 2310.2, "start": 2310.0, "text": "as"}, {"end": 2310.64, "start": 2310.2, "text": "to"}, {"end": 2311.04, "start": 2310.64, "text": "where"}, {"end": 2311.04, "start": 2311.04, "text": "to"}, {"end": 2311.76, "start": 2311.04, "text": "start."}, {"end": 2311.92, "start": 2311.76, "text": "You"}, {"end": 2312.24, "start": 2311.92, "text": "might"}, {"end": 2312.28, "start": 2312.24, "text": "want"}, {"end": 2312.28, "start": 2312.28, "text": "to"}, {"end": 2312.36, "start": 2312.28, "text": "start"}, {"end": 2312.36, "start": 2312.36, "text": "in"}, {"end": 2312.36, "start": 2312.36, "text": "the"}, {"end": 2312.36, "start": 2312.36, "text": "middle."}, {"end": 2312.36, "start": 2312.36, "text": "And"}, {"end": 2312.72, "start": 2312.36, "text": "you"}, {"end": 2313.08, "start": 2312.72, "text": "might"}, {"end": 2313.08, "start": 2313.08, "text": "want"}, {"end": 2313.08, "start": 2313.08, "text": "to"}, {"end": 2313.12, "start": 2313.08, "text": "work"}, {"end": 2313.76, "start": 2313.12, "text": "your"}, {"end": 2314.4, "start": 2313.76, "text": "way"}, {"end": 2315.12, "start": 2314.4, "text": "left"}, {"end": 2315.56, "start": 2315.12, "text": "first."}, {"end": 2316.24, "start": 2315.56, "text": "Or"}, {"end": 2316.36, "start": 2316.24, "text": "you"}, {"end": 2316.6, "start": 2316.36, "text": "just"}, {"end": 2316.84, "start": 2316.6, "text": "keep"}, {"end": 2317.08, "start": 2316.84, "text": "going"}, {"end": 2317.8, "start": 2317.08, "text": "left,"}, {"end": 2318.04, "start": 2317.8, "text": "or"}, {"end": 2318.16, "start": 2318.04, "text": "keep"}, {"end": 2318.72, "start": 2318.16, "text": "going"}, {"end": 2319.24, "start": 2318.72, "text": "right."}, {"end": 2319.76, "start": 2319.24, "text": "And"}, {"end": 2319.92, "start": 2319.76, "text": "if"}, {"end": 2320.2, "start": 2319.92, "text": "you"}, {"end": 2320.2, "start": 2320.2, "text": "hit"}, {"end": 2320.44, "start": 2320.2, "text": "an"}, {"end": 2321.08, "start": 2320.44, "text": "edge,"}, {"end": 2321.12, "start": 2321.08, "text": "you"}, {"end": 2321.32, "start": 2321.12, "text": "go"}, {"end": 2322.32, "start": 2321.32, "text": "down."}, {"end": 2322.56, "start": 2322.32, "text": "So"}, {"end": 2322.56, "start": 2322.56, "text": "you"}, {"end": 2322.76, "start": 2322.56, "text": "make"}, {"end": 2323.0, "start": 2322.76, "text": "some"}, {"end": 2323.92, "start": 2323.0, "text": "choices"}, {"end": 2324.12, "start": 2323.92, "text": "as"}, {"end": 2324.32, "start": 2324.12, "text": "to"}, {"end": 2324.48, "start": 2324.32, "text": "what"}, {"end": 2324.56, "start": 2324.48, "text": "the"}, {"end": 2324.96, "start": 2324.56, "text": "default"}, {"end": 2326.44, "start": 2324.96, "text": "traversal"}, {"end": 2326.96, "start": 2326.44, "text": "directions"}, {"end": 2327.28, "start": 2326.96, "text": "are."}, {"end": 2327.64, "start": 2327.28, "text": "And"}, {"end": 2327.72, "start": 2327.64, "text": "so"}, {"end": 2327.84, "start": 2327.72, "text": "if"}, {"end": 2328.36, "start": 2327.84, "text": "you"}, {"end": 2328.84, "start": 2328.36, "text": "say"}, {"end": 2328.88, "start": 2328.84, "text": "you"}, {"end": 2328.92, "start": 2328.88, "text": "want"}, {"end": 2328.92, "start": 2328.92, "text": "to"}, {"end": 2329.04, "start": 2328.92, "text": "start"}, {"end": 2329.04, "start": 2329.04, "text": "with"}, {"end": 2329.2, "start": 2329.04, "text": "12,"}, {"end": 2329.48, "start": 2329.2, "text": "you're"}, {"end": 2329.8, "start": 2329.48, "text": "going"}, {"end": 2329.88, "start": 2329.8, "text": "to"}, {"end": 2330.8, "start": 2329.88, "text": "go"}, {"end": 2331.2, "start": 2330.8, "text": "look"}, {"end": 2331.8, "start": 2331.2, "text": "for"}, {"end": 2332.44, "start": 2331.8, "text": "something"}, {"end": 2333.28, "start": 2332.44, "text": "to"}, {"end": 2334.0, "start": 2333.28, "text": "your"}, {"end": 2334.32, "start": 2334.0, "text": "left."}, {"end": 2334.88, "start": 2334.32, "text": "And"}, {"end": 2335.4, "start": 2334.88, "text": "if"}, {"end": 2335.68, "start": 2335.4, "text": "it's"}, {"end": 2335.84, "start": 2335.68, "text": "greater,"}, {"end": 2336.76, "start": 2335.84, "text": "then"}, {"end": 2337.16, "start": 2336.76, "text": "you're"}, {"end": 2337.76, "start": 2337.16, "text": "going"}, {"end": 2338.04, "start": 2337.76, "text": "to"}, {"end": 2338.6, "start": 2338.04, "text": "follow"}, {"end": 2339.28, "start": 2338.6, "text": "that"}, {"end": 2339.96, "start": 2339.28, "text": "direction."}], "text": " as to where to start. You might want to start in the middle. And you might want to work your way left first. Or you just keep going left, or keep going right. And if you hit an edge, you go down. So you make some choices as to what the default traversal directions are. And so if you say you want to start with 12, you're going to go look for something to your left. And if it's greater, then you're going to follow that direction."}, {"chunks": [{"end": 2340.08, "start": 2340.0, "text": "If"}, {"end": 2340.32, "start": 2340.08, "text": "it's"}, {"end": 2340.64, "start": 2340.32, "text": "less,"}, {"end": 2341.0, "start": 2340.64, "text": "then"}, {"end": 2341.56, "start": 2341.0, "text": "you're"}, {"end": 2341.72, "start": 2341.56, "text": "going"}, {"end": 2341.96, "start": 2341.72, "text": "to"}, {"end": 2342.24, "start": 2341.96, "text": "go"}, {"end": 2342.48, "start": 2342.24, "text": "in"}, {"end": 2342.76, "start": 2342.48, "text": "the"}, {"end": 2342.92, "start": 2342.76, "text": "other"}, {"end": 2343.56, "start": 2342.92, "text": "direction"}, {"end": 2343.64, "start": 2343.56, "text": "in"}, {"end": 2343.76, "start": 2343.64, "text": "this"}, {"end": 2344.04, "start": 2343.76, "text": "case,"}, {"end": 2344.16, "start": 2344.04, "text": "for"}, {"end": 2345.04, "start": 2344.16, "text": "example."}, {"end": 2345.2, "start": 2345.04, "text": "So"}, {"end": 2345.32, "start": 2345.2, "text": "in"}, {"end": 2345.84, "start": 2345.32, "text": "this"}, {"end": 2346.28, "start": 2345.84, "text": "case,"}, {"end": 2347.04, "start": 2346.28, "text": "you'll"}, {"end": 2347.28, "start": 2347.04, "text": "go"}, {"end": 2347.76, "start": 2347.28, "text": "12,"}, {"end": 2348.44, "start": 2347.76, "text": "13,"}, {"end": 2349.52, "start": 2348.44, "text": "14,"}, {"end": 2350.64, "start": 2349.52, "text": "15,"}, {"end": 2351.16, "start": 2350.64, "text": "16,"}, {"end": 2352.24, "start": 2351.16, "text": "17,"}, {"end": 2353.12, "start": 2352.24, "text": "19,"}, {"end": 2353.24, "start": 2353.12, "text": "and"}, {"end": 2354.28, "start": 2353.24, "text": "20."}, {"end": 2354.88, "start": 2354.28, "text": "And"}, {"end": 2355.04, "start": 2354.88, "text": "you'd"}, {"end": 2355.92, "start": 2355.04, "text": "find"}, {"end": 2356.32, "start": 2355.92, "text": "this"}, {"end": 2357.84, "start": 2356.32, "text": "peak."}, {"end": 2358.2, "start": 2357.84, "text": "Now,"}, {"end": 2358.52, "start": 2358.2, "text": "I"}, {"end": 2359.08, "start": 2358.52, "text": "haven't"}, {"end": 2359.08, "start": 2359.08, "text": "given"}, {"end": 2359.48, "start": 2359.08, "text": "you"}, {"end": 2359.84, "start": 2359.48, "text": "the"}, {"end": 2360.52, "start": 2359.84, "text": "specific"}, {"end": 2361.68, "start": 2360.52, "text": "details"}, {"end": 2362.6, "start": 2361.68, "text": "of"}, {"end": 2363.76, "start": 2362.6, "text": "a"}, {"end": 2365.56, "start": 2363.76, "text": "greedy"}, {"end": 2366.56, "start": 2365.56, "text": "ascent"}, {"end": 2369.96, "start": 2366.56, "text": "algorithm."}], "text": " If it's less, then you're going to go in the other direction in this case, for example. So in this case, you'll go 12, 13, 14, 15, 16, 17, 19, and 20. And you'd find this peak. Now, I haven't given you the specific details of a greedy ascent algorithm."}, {"chunks": [{"end": 2371.88, "start": 2370.0, "text": "The"}, {"end": 2372.08, "start": 2371.88, "text": "worst"}, {"end": 2372.64, "start": 2372.08, "text": "case"}, {"end": 2373.4, "start": 2372.64, "text": "possibilities"}, {"end": 2373.72, "start": 2373.4, "text": "here"}, {"end": 2373.92, "start": 2373.72, "text": "with"}, {"end": 2374.24, "start": 2373.92, "text": "respect"}, {"end": 2374.92, "start": 2374.24, "text": "to"}, {"end": 2375.08, "start": 2374.92, "text": "a"}, {"end": 2375.32, "start": 2375.08, "text": "given"}, {"end": 2376.36, "start": 2375.32, "text": "matrix"}, {"end": 2376.68, "start": 2376.36, "text": "and"}, {"end": 2376.84, "start": 2376.68, "text": "for"}, {"end": 2377.2, "start": 2376.84, "text": "any"}, {"end": 2377.56, "start": 2377.2, "text": "given"}, {"end": 2378.04, "start": 2377.56, "text": "starting"}, {"end": 2378.92, "start": 2378.04, "text": "point"}, {"end": 2379.12, "start": 2378.92, "text": "and"}, {"end": 2379.44, "start": 2379.12, "text": "for"}, {"end": 2379.76, "start": 2379.44, "text": "any"}, {"end": 2380.52, "start": 2379.76, "text": "given"}, {"end": 2381.64, "start": 2380.52, "text": "strategy"}, {"end": 2381.72, "start": 2381.64, "text": "in"}, {"end": 2382.0, "start": 2381.72, "text": "terms"}, {"end": 2382.04, "start": 2382.0, "text": "of"}, {"end": 2382.4, "start": 2382.04, "text": "choosing"}, {"end": 2382.76, "start": 2382.4, "text": "left"}, {"end": 2383.24, "start": 2382.76, "text": "first"}, {"end": 2384.4, "start": 2383.24, "text": "versus"}, {"end": 2384.72, "start": 2384.4, "text": "right"}, {"end": 2385.56, "start": 2384.72, "text": "first"}, {"end": 2385.76, "start": 2385.56, "text": "or"}, {"end": 2386.44, "start": 2385.76, "text": "down"}, {"end": 2386.8, "start": 2386.44, "text": "first"}, {"end": 2387.2, "start": 2386.8, "text": "versus"}, {"end": 2387.4, "start": 2387.2, "text": "up"}, {"end": 2388.0, "start": 2387.4, "text": "first,"}, {"end": 2388.08, "start": 2388.0, "text": "you"}, {"end": 2388.44, "start": 2388.08, "text": "will"}, {"end": 2388.64, "start": 2388.44, "text": "have"}, {"end": 2389.08, "start": 2388.64, "text": "a"}, {"end": 2389.64, "start": 2389.08, "text": "situation"}, {"end": 2390.12, "start": 2389.64, "text": "where,"}, {"end": 2390.8, "start": 2390.12, "text": "just"}, {"end": 2391.0, "start": 2390.8, "text": "like"}, {"end": 2391.2, "start": 2391.0, "text": "we"}, {"end": 2391.76, "start": 2391.2, "text": "had"}, {"end": 2391.84, "start": 2391.76, "text": "in"}, {"end": 2392.24, "start": 2391.84, "text": "the"}, {"end": 2392.76, "start": 2392.24, "text": "1D"}, {"end": 2393.8, "start": 2392.76, "text": "case,"}, {"end": 2393.92, "start": 2393.8, "text": "you"}, {"end": 2394.32, "start": 2393.92, "text": "may"}, {"end": 2394.48, "start": 2394.32, "text": "end"}, {"end": 2394.92, "start": 2394.48, "text": "up"}, {"end": 2397.12, "start": 2394.92, "text": "touching"}, {"end": 2397.76, "start": 2397.12, "text": "a"}, {"end": 2398.4, "start": 2397.76, "text": "large"}, {"end": 2399.44, "start": 2398.4, "text": "fraction"}, {"end": 2399.72, "start": 2399.44, "text": "of"}, {"end": 2399.96, "start": 2399.72, "text": "the"}], "text": " The worst case possibilities here with respect to a given matrix and for any given starting point and for any given strategy in terms of choosing left first versus right first or down first versus up first, you will have a situation where, just like we had in the 1D case, you may end up touching a large fraction of the"}, {"chunks": [{"end": 2400.48, "start": 2400.0, "text": "elements"}, {"end": 2400.52, "start": 2400.48, "text": "in"}, {"end": 2400.68, "start": 2400.52, "text": "this"}, {"end": 2401.04, "start": 2400.68, "text": "2D"}, {"end": 2402.0, "start": 2401.04, "text": "array."}, {"end": 2402.2, "start": 2402.0, "text": "So"}, {"end": 2402.76, "start": 2402.2, "text": "in"}, {"end": 2403.16, "start": 2402.76, "text": "this"}, {"end": 2403.68, "start": 2403.16, "text": "case,"}, {"end": 2404.04, "start": 2403.68, "text": "we"}, {"end": 2404.36, "start": 2404.04, "text": "ended"}, {"end": 2404.84, "start": 2404.36, "text": "up"}, {"end": 2404.96, "start": 2404.84, "text": "touching"}, {"end": 2405.12, "start": 2404.96, "text": "a"}, {"end": 2405.52, "start": 2405.12, "text": "bunch"}, {"end": 2405.72, "start": 2405.52, "text": "of"}, {"end": 2406.04, "start": 2405.72, "text": "different"}, {"end": 2406.64, "start": 2406.04, "text": "elements."}, {"end": 2406.92, "start": 2406.64, "text": "And"}, {"end": 2407.04, "start": 2406.92, "text": "it's"}, {"end": 2407.28, "start": 2407.04, "text": "quite"}, {"end": 2408.56, "start": 2407.28, "text": "possible"}, {"end": 2408.92, "start": 2408.56, "text": "that"}, {"end": 2409.24, "start": 2408.92, "text": "you"}, {"end": 2409.56, "start": 2409.24, "text": "could"}, {"end": 2409.8, "start": 2409.56, "text": "end"}, {"end": 2409.92, "start": 2409.8, "text": "up"}, {"end": 2410.72, "start": 2409.92, "text": "touching,"}, {"end": 2411.0, "start": 2410.72, "text": "starting"}, {"end": 2411.2, "start": 2411.0, "text": "from"}, {"end": 2411.36, "start": 2411.2, "text": "the"}, {"end": 2411.68, "start": 2411.36, "text": "midpoint,"}, {"end": 2411.72, "start": 2411.68, "text": "you"}, {"end": 2411.76, "start": 2411.72, "text": "could"}, {"end": 2412.0, "start": 2411.76, "text": "end"}, {"end": 2412.12, "start": 2412.0, "text": "up"}, {"end": 2412.56, "start": 2412.12, "text": "touching"}, {"end": 2412.76, "start": 2412.56, "text": "half"}, {"end": 2413.04, "start": 2412.76, "text": "the"}, {"end": 2413.76, "start": 2413.04, "text": "elements,"}, {"end": 2414.44, "start": 2413.76, "text": "and"}, {"end": 2414.76, "start": 2414.44, "text": "in"}, {"end": 2414.92, "start": 2414.76, "text": "some"}, {"end": 2415.28, "start": 2414.92, "text": "cases,"}, {"end": 2415.68, "start": 2415.28, "text": "touching"}, {"end": 2416.0, "start": 2415.68, "text": "all"}, {"end": 2416.16, "start": 2416.0, "text": "of"}, {"end": 2416.24, "start": 2416.16, "text": "the"}, {"end": 2416.88, "start": 2416.24, "text": "elements."}, {"end": 2417.44, "start": 2416.88, "text": "So"}, {"end": 2417.84, "start": 2417.44, "text": "if"}, {"end": 2418.08, "start": 2417.84, "text": "you"}, {"end": 2418.2, "start": 2418.08, "text": "do"}, {"end": 2418.32, "start": 2418.2, "text": "a"}, {"end": 2418.76, "start": 2418.32, "text": "worst"}, {"end": 2419.8, "start": 2418.76, "text": "case"}, {"end": 2420.36, "start": 2419.8, "text": "analysis"}, {"end": 2420.4, "start": 2420.36, "text": "of"}, {"end": 2420.76, "start": 2420.4, "text": "this"}, {"end": 2422.96, "start": 2420.76, "text": "algorithm,"}, {"end": 2423.12, "start": 2422.96, "text": "a"}, {"end": 2423.36, "start": 2423.12, "text": "particular"}, {"end": 2424.08, "start": 2423.36, "text": "algorithm"}, {"end": 2424.24, "start": 2424.08, "text": "with"}, {"end": 2424.52, "start": 2424.24, "text": "particular"}, {"end": 2425.16, "start": 2424.52, "text": "choices"}, {"end": 2425.48, "start": 2425.16, "text": "in"}, {"end": 2425.92, "start": 2425.48, "text": "terms"}, {"end": 2426.76, "start": 2425.92, "text": "of"}, {"end": 2426.96, "start": 2426.76, "text": "the"}, {"end": 2427.56, "start": 2426.96, "text": "starting"}, {"end": 2428.36, "start": 2427.56, "text": "point"}, {"end": 2428.44, "start": 2428.36, "text": "and"}, {"end": 2428.52, "start": 2428.44, "text": "the"}, {"end": 2429.04, "start": 2428.52, "text": "direction"}, {"end": 2429.08, "start": 2429.04, "text": "of"}, {"end": 2429.96, "start": 2429.08, "text": "search,"}], "text": " elements in this 2D array. So in this case, we ended up touching a bunch of different elements. And it's quite possible that you could end up touching, starting from the midpoint, you could end up touching half the elements, and in some cases, touching all of the elements. So if you do a worst case analysis of this algorithm, a particular algorithm with particular choices in terms of the starting point and the direction of search,"}, {"chunks": [{"end": 2430.4, "start": 2430.0, "text": "A"}, {"end": 2430.52, "start": 2430.4, "text": "greedy"}, {"end": 2431.08, "start": 2430.52, "text": "ascent"}, {"end": 2431.44, "start": 2431.08, "text": "algorithm"}, {"end": 2431.56, "start": 2431.44, "text": "would"}, {"end": 2431.88, "start": 2431.56, "text": "have"}, {"end": 2432.24, "start": 2431.88, "text": "theta"}, {"end": 2432.52, "start": 2432.24, "text": "nm"}, {"end": 2433.76, "start": 2432.52, "text": "complexity."}, {"end": 2434.32, "start": 2433.76, "text": "And"}, {"end": 2434.52, "start": 2434.32, "text": "in"}, {"end": 2434.92, "start": 2434.52, "text": "the"}, {"end": 2435.4, "start": 2434.92, "text": "case"}, {"end": 2437.08, "start": 2435.4, "text": "where"}, {"end": 2437.56, "start": 2437.08, "text": "n"}, {"end": 2438.16, "start": 2437.56, "text": "equals"}, {"end": 2438.56, "start": 2438.16, "text": "m,"}, {"end": 2439.56, "start": 2438.56, "text": "or"}, {"end": 2440.04, "start": 2439.56, "text": "m"}, {"end": 2440.56, "start": 2440.04, "text": "equals"}, {"end": 2440.8, "start": 2440.56, "text": "n,"}, {"end": 2440.96, "start": 2440.8, "text": "you'd"}, {"end": 2441.56, "start": 2440.96, "text": "have"}, {"end": 2442.48, "start": 2441.56, "text": "theta"}, {"end": 2442.72, "start": 2442.48, "text": "n"}, {"end": 2443.32, "start": 2442.72, "text": "squared"}, {"end": 2444.84, "start": 2443.32, "text": "complexity."}, {"end": 2446.2, "start": 2444.84, "text": "I"}, {"end": 2446.72, "start": 2446.2, "text": "won't"}, {"end": 2447.0, "start": 2446.72, "text": "spend"}, {"end": 2447.24, "start": 2447.0, "text": "very"}, {"end": 2447.52, "start": 2447.24, "text": "much"}, {"end": 2447.96, "start": 2447.52, "text": "time"}, {"end": 2448.08, "start": 2447.96, "text": "on"}, {"end": 2448.44, "start": 2448.08, "text": "this"}, {"end": 2449.16, "start": 2448.44, "text": "because"}, {"end": 2449.44, "start": 2449.16, "text": "I"}, {"end": 2449.68, "start": 2449.44, "text": "want"}, {"end": 2449.84, "start": 2449.68, "text": "to"}, {"end": 2450.04, "start": 2449.84, "text": "talk"}, {"end": 2450.32, "start": 2450.04, "text": "to"}, {"end": 2450.96, "start": 2450.32, "text": "you"}, {"end": 2451.16, "start": 2450.96, "text": "about"}, {"end": 2451.56, "start": 2451.16, "text": "the"}, {"end": 2452.32, "start": 2451.56, "text": "divide"}, {"end": 2452.48, "start": 2452.32, "text": "and"}, {"end": 2452.68, "start": 2452.48, "text": "conquer"}, {"end": 2453.84, "start": 2452.68, "text": "versions"}, {"end": 2454.32, "start": 2453.84, "text": "of"}, {"end": 2455.24, "start": 2454.32, "text": "this"}, {"end": 2455.76, "start": 2455.24, "text": "algorithm"}, {"end": 2456.32, "start": 2455.76, "text": "for"}, {"end": 2456.56, "start": 2456.32, "text": "the"}, {"end": 2456.92, "start": 2456.56, "text": "2D"}, {"end": 2457.8, "start": 2456.92, "text": "peak."}, {"end": 2458.64, "start": 2457.8, "text": "But"}, {"end": 2459.24, "start": 2458.64, "text": "hopefully"}, {"end": 2459.64, "start": 2459.24, "text": "you're"}, {"end": 2459.64, "start": 2459.64, "text": "all"}, {"end": 2459.96, "start": 2459.64, "text": "with"}], "text": " A greedy ascent algorithm would have theta nm complexity. And in the case where n equals m, or m equals n, you'd have theta n squared complexity. I won't spend very much time on this because I want to talk to you about the divide and conquer versions of this algorithm for the 2D peak. But hopefully you're all with"}, {"chunks": [{"end": 2460.32, "start": 2460.0, "text": "me"}, {"end": 2460.44, "start": 2460.32, "text": "with"}, {"end": 2460.8, "start": 2460.44, "text": "respect"}, {"end": 2461.04, "start": 2460.8, "text": "to"}, {"end": 2461.24, "start": 2461.04, "text": "what"}, {"end": 2461.32, "start": 2461.24, "text": "the"}, {"end": 2461.56, "start": 2461.32, "text": "worst"}, {"end": 2461.84, "start": 2461.56, "text": "case"}, {"end": 2462.24, "start": 2461.84, "text": "complexity"}, {"end": 2463.52, "start": 2462.24, "text": "is."}, {"end": 2465.16, "start": 2463.52, "text": "All"}, {"end": 2465.6, "start": 2465.16, "text": "right?"}, {"end": 2466.2, "start": 2465.6, "text": "People"}, {"end": 2466.44, "start": 2466.2, "text": "buy"}, {"end": 2466.52, "start": 2466.44, "text": "that?"}, {"end": 2466.52, "start": 2466.52, "text": "Yeah,"}, {"end": 2466.96, "start": 2466.52, "text": "question"}, {"end": 2467.36, "start": 2466.96, "text": "back"}, {"end": 2467.52, "start": 2467.36, "text": "there."}, {"end": 2467.72, "start": 2467.52, "text": "Is"}, {"end": 2467.96, "start": 2467.72, "text": "that"}, {"end": 2468.24, "start": 2467.96, "text": "an"}, {"end": 2469.0, "start": 2468.24, "text": "approximation"}, {"end": 2469.56, "start": 2469.0, "text": "or"}, {"end": 2470.4, "start": 2469.56, "text": "can"}, {"end": 2471.08, "start": 2470.4, "text": "you"}, {"end": 2472.6, "start": 2471.08, "text": "actually"}, {"end": 2472.96, "start": 2472.6, "text": "get"}, {"end": 2473.16, "start": 2472.96, "text": "to"}, {"end": 2473.68, "start": 2473.16, "text": "n"}, {"end": 2473.96, "start": 2473.68, "text": "to"}, {"end": 2474.6, "start": 2473.96, "text": "m"}, {"end": 2475.44, "start": 2474.6, "text": "traversal?"}, {"end": 2475.64, "start": 2475.44, "text": "So"}, {"end": 2476.4, "start": 2475.64, "text": "there"}, {"end": 2476.64, "start": 2476.4, "text": "are"}, {"end": 2477.36, "start": 2476.64, "text": "specific"}, {"end": 2477.6, "start": 2477.36, "text": "greedy"}, {"end": 2477.96, "start": 2477.6, "text": "ascent"}, {"end": 2478.76, "start": 2477.96, "text": "algorithms"}, {"end": 2478.92, "start": 2478.76, "text": "and"}, {"end": 2479.36, "start": 2478.92, "text": "specific"}, {"end": 2480.44, "start": 2479.36, "text": "matrices"}, {"end": 2481.16, "start": 2480.44, "text": "where"}, {"end": 2481.28, "start": 2481.16, "text": "if"}, {"end": 2481.4, "start": 2481.28, "text": "I"}, {"end": 2481.52, "start": 2481.4, "text": "give"}, {"end": 2481.64, "start": 2481.52, "text": "you"}, {"end": 2481.96, "start": 2481.64, "text": "the"}, {"end": 2482.28, "start": 2481.96, "text": "code"}, {"end": 2482.76, "start": 2482.28, "text": "for"}, {"end": 2482.92, "start": 2482.76, "text": "the"}, {"end": 2483.44, "start": 2482.92, "text": "algorithm"}, {"end": 2483.6, "start": 2483.44, "text": "and"}, {"end": 2483.68, "start": 2483.6, "text": "I"}, {"end": 2483.68, "start": 2483.68, "text": "give"}, {"end": 2483.8, "start": 2483.68, "text": "you"}, {"end": 2483.92, "start": 2483.8, "text": "a"}, {"end": 2483.96, "start": 2483.92, "text": "specific"}, {"end": 2484.68, "start": 2483.96, "text": "matrix"}, {"end": 2485.04, "start": 2484.68, "text": "that"}, {"end": 2485.32, "start": 2485.04, "text": "I"}, {"end": 2485.6, "start": 2485.32, "text": "could"}, {"end": 2485.8, "start": 2485.6, "text": "make"}, {"end": 2485.96, "start": 2485.8, "text": "you"}, {"end": 2486.44, "start": 2485.96, "text": "touch"}, {"end": 2486.84, "start": 2486.44, "text": "all"}, {"end": 2487.36, "start": 2486.84, "text": "of"}, {"end": 2487.56, "start": 2487.36, "text": "these"}, {"end": 2488.16, "start": 2487.56, "text": "elements."}, {"end": 2488.32, "start": 2488.16, "text": "That's"}, {"end": 2488.84, "start": 2488.32, "text": "correct."}, {"end": 2489.12, "start": 2488.84, "text": "So"}, {"end": 2489.2, "start": 2489.12, "text": "if"}, {"end": 2489.36, "start": 2489.2, "text": "you're"}, {"end": 2489.4, "start": 2489.36, "text": "talking"}, {"end": 2489.56, "start": 2489.4, "text": "about"}, {"end": 2489.8, "start": 2489.56, "text": "worst"}, {"end": 2489.96, "start": 2489.8, "text": "case,"}], "text": " me with respect to what the worst case complexity is. All right? People buy that? Yeah, question back there. Is that an approximation or can you actually get to n to m traversal? So there are specific greedy ascent algorithms and specific matrices where if I give you the code for the algorithm and I give you a specific matrix that I could make you touch all of these elements. That's correct. So if you're talking about worst case,"}, {"chunks": [{"end": 2490.6, "start": 2490.0, "text": "You're"}, {"end": 2490.96, "start": 2490.6, "text": "being"}, {"end": 2491.24, "start": 2490.96, "text": "very"}, {"end": 2492.0, "start": 2491.24, "text": "paranoid"}, {"end": 2492.12, "start": 2492.0, "text": "when"}, {"end": 2492.2, "start": 2492.12, "text": "you"}, {"end": 2492.24, "start": 2492.2, "text": "talk"}, {"end": 2492.56, "start": 2492.24, "text": "about"}, {"end": 2492.84, "start": 2492.56, "text": "worst"}, {"end": 2493.16, "start": 2492.84, "text": "case"}, {"end": 2494.08, "start": 2493.16, "text": "complexity."}, {"end": 2494.72, "start": 2494.08, "text": "And"}, {"end": 2495.32, "start": 2494.72, "text": "so"}, {"end": 2495.6, "start": 2495.32, "text": "I'm"}, {"end": 2496.16, "start": 2495.6, "text": "hand"}, {"end": 2497.12, "start": 2496.16, "text": "waving"}, {"end": 2497.28, "start": 2497.12, "text": "a"}, {"end": 2497.6, "start": 2497.28, "text": "bit"}, {"end": 2498.28, "start": 2497.6, "text": "here"}, {"end": 2498.96, "start": 2498.28, "text": "simply"}, {"end": 2499.72, "start": 2498.96, "text": "because"}, {"end": 2500.32, "start": 2499.72, "text": "I"}, {"end": 2500.6, "start": 2500.32, "text": "haven't"}, {"end": 2500.6, "start": 2500.6, "text": "given"}, {"end": 2500.6, "start": 2500.6, "text": "you"}, {"end": 2500.64, "start": 2500.6, "text": "the"}, {"end": 2500.92, "start": 2500.64, "text": "specifics"}, {"end": 2501.04, "start": 2500.92, "text": "of"}, {"end": 2501.24, "start": 2501.04, "text": "the"}, {"end": 2501.68, "start": 2501.24, "text": "algorithm"}, {"end": 2501.84, "start": 2501.68, "text": "yet."}, {"end": 2502.08, "start": 2501.84, "text": "This"}, {"end": 2502.12, "start": 2502.08, "text": "is"}, {"end": 2502.24, "start": 2502.12, "text": "really"}, {"end": 2502.28, "start": 2502.24, "text": "a"}, {"end": 2502.28, "start": 2502.28, "text": "set"}, {"end": 2502.36, "start": 2502.28, "text": "of"}, {"end": 2502.84, "start": 2502.36, "text": "algorithms"}, {"end": 2503.52, "start": 2502.84, "text": "because"}, {"end": 2503.88, "start": 2503.52, "text": "I"}, {"end": 2504.64, "start": 2503.88, "text": "haven't"}, {"end": 2504.72, "start": 2504.64, "text": "given"}, {"end": 2504.72, "start": 2504.72, "text": "you"}, {"end": 2505.28, "start": 2504.72, "text": "the"}, {"end": 2505.64, "start": 2505.28, "text": "code."}, {"end": 2505.68, "start": 2505.64, "text": "I"}, {"end": 2506.24, "start": 2505.68, "text": "haven't"}, {"end": 2506.44, "start": 2506.24, "text": "told"}, {"end": 2506.48, "start": 2506.44, "text": "you"}, {"end": 2506.72, "start": 2506.48, "text": "where"}, {"end": 2506.8, "start": 2506.72, "text": "it"}, {"end": 2507.52, "start": 2506.8, "text": "starts"}, {"end": 2507.64, "start": 2507.52, "text": "and"}, {"end": 2507.88, "start": 2507.64, "text": "which"}, {"end": 2508.32, "start": 2507.88, "text": "direction"}, {"end": 2508.36, "start": 2508.32, "text": "it"}, {"end": 2509.08, "start": 2508.36, "text": "goes."}, {"end": 2509.48, "start": 2509.08, "text": "But"}, {"end": 2509.64, "start": 2509.48, "text": "you"}, {"end": 2510.08, "start": 2509.64, "text": "go"}, {"end": 2510.16, "start": 2510.08, "text": "do"}, {"end": 2510.84, "start": 2510.16, "text": "that,"}, {"end": 2511.24, "start": 2510.84, "text": "fix"}, {"end": 2511.52, "start": 2511.24, "text": "it,"}, {"end": 2512.04, "start": 2511.52, "text": "and"}, {"end": 2512.44, "start": 2512.04, "text": "I"}, {"end": 2512.48, "start": 2512.44, "text": "would"}, {"end": 2512.6, "start": 2512.48, "text": "be"}, {"end": 2512.68, "start": 2512.6, "text": "the"}, {"end": 2513.12, "start": 2512.68, "text": "person"}, {"end": 2513.16, "start": 2513.12, "text": "who"}, {"end": 2513.52, "start": 2513.16, "text": "tries"}, {"end": 2513.52, "start": 2513.52, "text": "to"}, {"end": 2513.68, "start": 2513.52, "text": "find"}, {"end": 2513.92, "start": 2513.68, "text": "the"}, {"end": 2514.2, "start": 2513.92, "text": "worst"}, {"end": 2514.48, "start": 2514.2, "text": "case"}, {"end": 2515.36, "start": 2514.48, "text": "complexity."}, {"end": 2515.92, "start": 2515.36, "text": "Certainly,"}, {"end": 2516.28, "start": 2515.92, "text": "it's"}, {"end": 2516.6, "start": 2516.28, "text": "very"}, {"end": 2516.8, "start": 2516.6, "text": "easy"}, {"end": 2516.88, "start": 2516.8, "text": "to"}, {"end": 2517.08, "start": 2516.88, "text": "get"}, {"end": 2517.48, "start": 2517.08, "text": "to"}, {"end": 2518.2, "start": 2517.48, "text": "theta"}, {"end": 2518.52, "start": 2518.2, "text": "and"}, {"end": 2518.6, "start": 2518.52, "text": "m"}, {"end": 2518.6, "start": 2518.6, "text": "in"}, {"end": 2518.88, "start": 2518.6, "text": "terms"}, {"end": 2519.0, "start": 2518.88, "text": "of"}, {"end": 2519.24, "start": 2519.0, "text": "having"}, {"end": 2519.52, "start": 2519.24, "text": "some"}, {"end": 2519.96, "start": 2519.52, "text": "constant"}], "text": " You're being very paranoid when you talk about worst case complexity. And so I'm hand waving a bit here simply because I haven't given you the specifics of the algorithm yet. This is really a set of algorithms because I haven't given you the code. I haven't told you where it starts and which direction it goes. But you go do that, fix it, and I would be the person who tries to find the worst case complexity. Certainly, it's very easy to get to theta and m in terms of having some constant"}, {"chunks": [{"end": 2521.4, "start": 2520.0, "text": "Multiplying"}, {"end": 2521.92, "start": 2521.4, "text": "n"}, {"end": 2523.08, "start": 2521.92, "text": "times"}, {"end": 2523.2, "start": 2523.08, "text": "m."}, {"end": 2523.48, "start": 2523.2, "text": "But"}, {"end": 2523.56, "start": 2523.48, "text": "you"}, {"end": 2523.96, "start": 2523.56, "text": "can"}, {"end": 2524.36, "start": 2523.96, "text": "definitely"}, {"end": 2524.6, "start": 2524.36, "text": "get"}, {"end": 2525.12, "start": 2524.6, "text": "to"}, {"end": 2525.32, "start": 2525.12, "text": "that"}, {"end": 2525.76, "start": 2525.32, "text": "constant"}, {"end": 2526.4, "start": 2525.76, "text": "being"}, {"end": 2526.76, "start": 2526.4, "text": "very"}, {"end": 2527.96, "start": 2526.76, "text": "close"}, {"end": 2528.44, "start": 2527.96, "text": "to"}, {"end": 2528.6, "start": 2528.44, "text": "1,"}, {"end": 2529.88, "start": 2528.6, "text": "if"}, {"end": 2530.04, "start": 2529.88, "text": "not"}, {"end": 2530.2, "start": 2530.04, "text": "1."}, {"end": 2531.32, "start": 2530.2, "text": "All"}, {"end": 2532.16, "start": 2531.32, "text": "right."}, {"end": 2532.68, "start": 2532.16, "text": "So"}, {"end": 2533.16, "start": 2532.68, "text": "let's"}, {"end": 2533.64, "start": 2533.16, "text": "talk"}, {"end": 2534.2, "start": 2533.64, "text": "about"}, {"end": 2534.8, "start": 2534.2, "text": "divide"}, {"end": 2535.52, "start": 2534.8, "text": "and"}, {"end": 2535.84, "start": 2535.52, "text": "conquer."}, {"end": 2536.04, "start": 2535.84, "text": "Let's"}, {"end": 2537.28, "start": 2536.04, "text": "say"}, {"end": 2537.88, "start": 2537.28, "text": "that"}, {"end": 2538.04, "start": 2537.88, "text": "I"}, {"end": 2538.24, "start": 2538.04, "text": "did"}, {"end": 2538.56, "start": 2538.24, "text": "something"}, {"end": 2538.84, "start": 2538.56, "text": "like"}, {"end": 2539.2, "start": 2538.84, "text": "this,"}, {"end": 2539.52, "start": 2539.2, "text": "where"}, {"end": 2539.52, "start": 2539.52, "text": "I"}, {"end": 2539.8, "start": 2539.52, "text": "just"}, {"end": 2540.28, "start": 2539.8, "text": "tried"}, {"end": 2541.36, "start": 2540.28, "text": "to"}, {"end": 2541.48, "start": 2541.36, "text": "jam"}, {"end": 2541.92, "start": 2541.48, "text": "the"}, {"end": 2542.6, "start": 2541.92, "text": "binary"}, {"end": 2544.0, "start": 2542.6, "text": "search"}, {"end": 2544.84, "start": 2544.0, "text": "algorithm"}, {"end": 2544.88, "start": 2544.84, "text": "into"}, {"end": 2545.0, "start": 2544.88, "text": "the"}, {"end": 2545.32, "start": 2545.0, "text": "2D"}, {"end": 2549.96, "start": 2545.32, "text": "version."}], "text": " Multiplying n times m. But you can definitely get to that constant being very close to 1, if not 1. All right. So let's talk about divide and conquer. Let's say that I did something like this, where I just tried to jam the binary search algorithm into the 2D version."}, {"chunks": [{"end": 2552.92, "start": 2550.0, "text": "So"}, {"end": 2556.64, "start": 2552.92, "text": "what"}, {"end": 2557.2, "start": 2556.64, "text": "I'm"}, {"end": 2557.56, "start": 2557.2, "text": "going"}, {"end": 2557.84, "start": 2557.56, "text": "to"}, {"end": 2558.64, "start": 2557.84, "text": "do"}, {"end": 2563.8, "start": 2558.64, "text": "is"}, {"end": 2564.28, "start": 2563.8, "text": "I'm"}, {"end": 2565.04, "start": 2564.28, "text": "going"}, {"end": 2565.2, "start": 2565.04, "text": "to"}, {"end": 2566.32, "start": 2565.2, "text": "pick"}, {"end": 2566.56, "start": 2566.32, "text": "the"}, {"end": 2569.24, "start": 2566.56, "text": "middle"}, {"end": 2571.76, "start": 2569.24, "text": "column,"}, {"end": 2572.2, "start": 2571.76, "text": "j"}, {"end": 2572.92, "start": 2572.2, "text": "equals"}, {"end": 2573.12, "start": 2572.92, "text": "m"}, {"end": 2573.48, "start": 2573.12, "text": "over"}, {"end": 2575.4, "start": 2573.48, "text": "2."}, {"end": 2575.96, "start": 2575.4, "text": "And"}, {"end": 2577.12, "start": 2575.96, "text": "I'm"}, {"end": 2577.24, "start": 2577.12, "text": "going"}, {"end": 2577.76, "start": 2577.24, "text": "to"}, {"end": 2578.04, "start": 2577.76, "text": "find"}, {"end": 2578.48, "start": 2578.04, "text": "a"}, {"end": 2578.76, "start": 2578.48, "text": "1D"}, {"end": 2579.96, "start": 2578.76, "text": "peak"}], "text": " So what I'm going to do is I'm going to pick the middle column, j equals m over 2. And I'm going to find a 1D peak"}, {"chunks": [{"end": 2580.28, "start": 2580.0, "text": "using"}, {"end": 2581.32, "start": 2580.28, "text": "whatever"}, {"end": 2582.16, "start": 2581.32, "text": "algorithm"}, {"end": 2582.48, "start": 2582.16, "text": "I"}, {"end": 2582.68, "start": 2582.48, "text": "want."}, {"end": 2583.16, "start": 2582.68, "text": "And"}, {"end": 2583.64, "start": 2583.16, "text": "I'll"}, {"end": 2584.28, "start": 2583.64, "text": "probably"}, {"end": 2584.84, "start": 2584.28, "text": "end"}, {"end": 2585.2, "start": 2584.84, "text": "up"}, {"end": 2585.28, "start": 2585.2, "text": "using"}, {"end": 2585.56, "start": 2585.28, "text": "the"}, {"end": 2585.68, "start": 2585.56, "text": "more"}, {"end": 2585.88, "start": 2585.68, "text": "efficient"}, {"end": 2586.2, "start": 2585.88, "text": "algorithm,"}, {"end": 2586.36, "start": 2586.2, "text": "the"}, {"end": 2586.6, "start": 2586.36, "text": "binary"}, {"end": 2586.96, "start": 2586.6, "text": "search"}, {"end": 2587.28, "start": 2586.96, "text": "version"}, {"end": 2587.52, "start": 2587.28, "text": "that's"}, {"end": 2587.84, "start": 2587.52, "text": "gone"}, {"end": 2588.2, "start": 2587.84, "text": "all"}, {"end": 2588.52, "start": 2588.2, "text": "the"}, {"end": 2588.56, "start": 2588.52, "text": "way"}, {"end": 2588.68, "start": 2588.56, "text": "to"}, {"end": 2588.96, "start": 2588.68, "text": "the"}, {"end": 2589.6, "start": 2588.96, "text": "left"}, {"end": 2589.68, "start": 2589.6, "text": "of"}, {"end": 2590.28, "start": 2589.68, "text": "the"}, {"end": 2590.4, "start": 2590.28, "text": "board"}, {"end": 2590.8, "start": 2590.4, "text": "there."}, {"end": 2590.84, "start": 2590.8, "text": "And"}, {"end": 2591.0, "start": 2590.84, "text": "let's"}, {"end": 2591.68, "start": 2591.0, "text": "say"}, {"end": 2592.04, "start": 2591.68, "text": "I"}, {"end": 2592.32, "start": 2592.04, "text": "find"}, {"end": 2592.48, "start": 2592.32, "text": "a"}, {"end": 2592.92, "start": 2592.48, "text": "binary"}, {"end": 2594.0, "start": 2592.92, "text": "peak"}, {"end": 2594.48, "start": 2594.0, "text": "at"}, {"end": 2595.48, "start": 2594.48, "text": "ij."}, {"end": 2596.2, "start": 2595.48, "text": "Because"}, {"end": 2596.6, "start": 2596.2, "text": "I've"}, {"end": 2596.68, "start": 2596.6, "text": "picked"}, {"end": 2597.0, "start": 2596.68, "text": "a"}, {"end": 2600.32, "start": 2597.0, "text": "column,"}, {"end": 2600.84, "start": 2600.32, "text": "and"}, {"end": 2601.12, "start": 2600.84, "text": "I'm"}, {"end": 2601.6, "start": 2601.12, "text": "just"}, {"end": 2602.16, "start": 2601.6, "text": "finding"}, {"end": 2603.44, "start": 2602.16, "text": "a"}, {"end": 2603.56, "start": 2603.44, "text": "1D"}, {"end": 2603.56, "start": 2603.56, "text": "peak."}, {"end": 2604.16, "start": 2603.56, "text": "So"}, {"end": 2605.44, "start": 2604.16, "text": "this"}, {"end": 2605.64, "start": 2605.44, "text": "is"}, {"end": 2606.88, "start": 2605.64, "text": "j"}, {"end": 2608.8, "start": 2606.88, "text": "equals"}, {"end": 2609.12, "start": 2608.8, "text": "m"}, {"end": 2609.24, "start": 2609.12, "text": "over"}, {"end": 2609.24, "start": 2609.24, "text": "2."}, {"end": 2609.28, "start": 2609.24, "text": "That's"}, {"end": 2609.96, "start": 2609.28, "text": "i."}], "text": " using whatever algorithm I want. And I'll probably end up using the more efficient algorithm, the binary search version that's gone all the way to the left of the board there. And let's say I find a binary peak at ij. Because I've picked a column, and I'm just finding a 1D peak. So this is j equals m over 2. That's i."}, {"chunks": [{"end": 2610.44, "start": 2610.0, "text": "particular"}, {"end": 2611.04, "start": 2610.44, "text": "row"}, {"end": 2612.0, "start": 2611.04, "text": "i"}, {"end": 2612.84, "start": 2612.0, "text": "as"}, {"end": 2613.12, "start": 2612.84, "text": "a"}, {"end": 2615.64, "start": 2613.12, "text": "start"}, {"end": 2618.8, "start": 2615.64, "text": "to"}, {"end": 2620.4, "start": 2618.8, "text": "find"}, {"end": 2620.56, "start": 2620.4, "text": "a"}, {"end": 2620.92, "start": 2620.56, "text": "1D"}, {"end": 2621.2, "start": 2620.92, "text": "peak"}, {"end": 2621.96, "start": 2621.2, "text": "on"}, {"end": 2622.24, "start": 2621.96, "text": "row"}, {"end": 2622.4, "start": 2622.24, "text": "i."}, {"end": 2624.24, "start": 2622.4, "text": "And"}, {"end": 2625.04, "start": 2624.24, "text": "I"}, {"end": 2625.44, "start": 2625.04, "text": "stand"}, {"end": 2625.76, "start": 2625.44, "text": "up"}, {"end": 2626.36, "start": 2625.76, "text": "here"}, {"end": 2626.6, "start": 2626.36, "text": "and"}, {"end": 2627.4, "start": 2626.6, "text": "I'm"}, {"end": 2628.08, "start": 2627.4, "text": "really"}, {"end": 2628.92, "start": 2628.08, "text": "happy"}, {"end": 2630.2, "start": 2628.92, "text": "because"}, {"end": 2630.72, "start": 2630.2, "text": "I"}, {"end": 2631.08, "start": 2630.72, "text": "say,"}, {"end": 2632.12, "start": 2631.08, "text": "wow."}, {"end": 2632.68, "start": 2632.12, "text": "I"}, {"end": 2633.44, "start": 2632.68, "text": "picked"}, {"end": 2633.72, "start": 2633.44, "text": "a"}, {"end": 2633.88, "start": 2633.72, "text": "middle"}, {"end": 2634.12, "start": 2633.88, "text": "column."}, {"end": 2634.4, "start": 2634.12, "text": "I"}, {"end": 2635.24, "start": 2634.4, "text": "found"}, {"end": 2635.64, "start": 2635.24, "text": "a"}, {"end": 2636.04, "start": 2635.64, "text": "1D"}, {"end": 2636.4, "start": 2636.04, "text": "peak."}, {"end": 2636.84, "start": 2636.4, "text": "That"}, {"end": 2637.16, "start": 2636.84, "text": "is"}, {"end": 2637.68, "start": 2637.16, "text": "theta"}, {"end": 2637.8, "start": 2637.68, "text": "n"}, {"end": 2638.4, "start": 2637.8, "text": "complexity"}, {"end": 2639.04, "start": 2638.4, "text": "to"}, {"end": 2639.4, "start": 2639.04, "text": "find"}, {"end": 2639.72, "start": 2639.4, "text": "a"}, {"end": 2639.84, "start": 2639.72, "text": "1D"}, {"end": 2639.96, "start": 2639.84, "text": "peak"}], "text": " particular row i as a start to find a 1D peak on row i. And I stand up here and I'm really happy because I say, wow. I picked a middle column. I found a 1D peak. That is theta n complexity to find a 1D peak"}, {"chunks": [{"end": 2641.4, "start": 2640.0, "text": "We"}, {"end": 2642.48, "start": 2641.4, "text": "argued."}, {"end": 2642.88, "start": 2642.48, "text": "And"}, {"end": 2644.0, "start": 2642.88, "text": "once"}, {"end": 2644.4, "start": 2644.0, "text": "I"}, {"end": 2645.2, "start": 2644.4, "text": "theta"}, {"end": 2645.48, "start": 2645.2, "text": "m."}, {"end": 2646.44, "start": 2645.48, "text": "Oh,"}, {"end": 2646.68, "start": 2646.44, "text": "I'm"}, {"end": 2647.92, "start": 2646.68, "text": "sorry."}, {"end": 2648.36, "start": 2647.92, "text": "You're"}, {"end": 2649.32, "start": 2648.36, "text": "right."}, {"end": 2649.84, "start": 2649.32, "text": "The"}, {"end": 2650.76, "start": 2649.84, "text": "log"}, {"end": 2651.04, "start": 2650.76, "text": "n"}, {"end": 2652.2, "start": 2651.04, "text": "complexity,"}, {"end": 2652.56, "start": 2652.2, "text": "that's"}, {"end": 2652.8, "start": 2652.56, "text": "what"}, {"end": 2652.84, "start": 2652.8, "text": "this"}, {"end": 2653.52, "start": 2652.84, "text": "was."}, {"end": 2653.76, "start": 2653.52, "text": "Where"}, {"end": 2653.84, "start": 2653.76, "text": "do"}, {"end": 2654.92, "start": 2653.84, "text": "I"}, {"end": 2655.12, "start": 2654.92, "text": "have"}, {"end": 2655.2, "start": 2655.12, "text": "that"}, {"end": 2655.44, "start": 2655.2, "text": "here?"}, {"end": 2655.48, "start": 2655.44, "text": "Yeah,"}, {"end": 2655.76, "start": 2655.48, "text": "log"}, {"end": 2655.88, "start": 2655.76, "text": "n"}, {"end": 2656.4, "start": 2655.88, "text": "complexity."}, {"end": 2656.76, "start": 2656.4, "text": "Thanks,"}, {"end": 2657.72, "start": 2656.76, "text": "Eric."}, {"end": 2658.84, "start": 2657.72, "text": "And"}, {"end": 2659.32, "start": 2658.84, "text": "then"}, {"end": 2659.88, "start": 2659.32, "text": "once"}, {"end": 2660.2, "start": 2659.88, "text": "I"}, {"end": 2660.64, "start": 2660.2, "text": "do"}, {"end": 2660.92, "start": 2660.64, "text": "that,"}, {"end": 2661.36, "start": 2660.92, "text": "I"}, {"end": 2662.32, "start": 2661.36, "text": "can"}, {"end": 2663.48, "start": 2662.32, "text": "find"}, {"end": 2663.72, "start": 2663.48, "text": "a"}, {"end": 2664.08, "start": 2663.72, "text": "1D"}, {"end": 2664.32, "start": 2664.08, "text": "peak"}, {"end": 2664.68, "start": 2664.32, "text": "on"}, {"end": 2665.92, "start": 2664.68, "text": "rho"}, {"end": 2666.2, "start": 2665.92, "text": "i."}, {"end": 2666.2, "start": 2666.2, "text": "In"}, {"end": 2666.4, "start": 2666.2, "text": "this"}, {"end": 2666.72, "start": 2666.4, "text": "case,"}, {"end": 2666.8, "start": 2666.72, "text": "the"}, {"end": 2666.92, "start": 2666.8, "text": "rho"}, {"end": 2667.32, "start": 2666.92, "text": "i"}, {"end": 2667.56, "start": 2667.32, "text": "would"}, {"end": 2668.08, "start": 2667.56, "text": "be"}, {"end": 2668.32, "start": 2668.08, "text": "m"}, {"end": 2668.72, "start": 2668.32, "text": "y."}, {"end": 2668.96, "start": 2668.72, "text": "So"}, {"end": 2668.96, "start": 2668.96, "text": "it"}, {"end": 2668.96, "start": 2668.96, "text": "would"}, {"end": 2669.08, "start": 2668.96, "text": "be"}, {"end": 2669.44, "start": 2669.08, "text": "log"}, {"end": 2669.68, "start": 2669.44, "text": "m"}, {"end": 2669.96, "start": 2669.68, "text": "complexity."}], "text": " We argued. And once I theta m. Oh, I'm sorry. You're right. The log n complexity, that's what this was. Where do I have that here? Yeah, log n complexity. Thanks, Eric. And then once I do that, I can find a 1D peak on rho i. In this case, the rho i would be m y. So it would be log m complexity."}, {"chunks": [{"end": 2670.68, "start": 2670.0, "text": "If"}, {"end": 2670.96, "start": 2670.68, "text": "n"}, {"end": 2671.24, "start": 2670.96, "text": "equals"}, {"end": 2671.4, "start": 2671.24, "text": "m,"}, {"end": 2671.52, "start": 2671.4, "text": "then"}, {"end": 2671.76, "start": 2671.52, "text": "I"}, {"end": 2671.96, "start": 2671.76, "text": "have"}, {"end": 2672.16, "start": 2671.96, "text": "a"}, {"end": 2672.28, "start": 2672.16, "text": "couple"}, {"end": 2672.44, "start": 2672.28, "text": "of"}, {"end": 2672.88, "start": 2672.44, "text": "steps"}, {"end": 2673.04, "start": 2672.88, "text": "of"}, {"end": 2673.84, "start": 2673.04, "text": "log"}, {"end": 2674.08, "start": 2673.84, "text": "n,"}, {"end": 2675.04, "start": 2674.08, "text": "and"}, {"end": 2675.64, "start": 2675.04, "text": "I'm"}, {"end": 2676.04, "start": 2675.64, "text": "done."}, {"end": 2678.32, "start": 2676.04, "text": "Am"}, {"end": 2679.08, "start": 2678.32, "text": "I"}, {"end": 2679.48, "start": 2679.08, "text": "done?"}, {"end": 2679.84, "start": 2679.48, "text": "No."}, {"end": 2680.32, "start": 2679.84, "text": "Can"}, {"end": 2680.6, "start": 2680.32, "text": "someone"}, {"end": 2680.76, "start": 2680.6, "text": "tell"}, {"end": 2680.96, "start": 2680.76, "text": "me"}, {"end": 2681.6, "start": 2680.96, "text": "why"}, {"end": 2681.8, "start": 2681.6, "text": "I'm"}, {"end": 2682.6, "start": 2681.8, "text": "not"}, {"end": 2682.72, "start": 2682.6, "text": "done"}, {"end": 2684.16, "start": 2682.72, "text": "precisely?"}, {"end": 2684.28, "start": 2684.16, "text": "Yep."}, {"end": 2684.52, "start": 2684.28, "text": "Because"}, {"end": 2684.6, "start": 2684.52, "text": "when"}, {"end": 2684.68, "start": 2684.6, "text": "you"}, {"end": 2684.8, "start": 2684.68, "text": "do"}, {"end": 2685.12, "start": 2684.8, "text": "the"}, {"end": 2685.8, "start": 2685.12, "text": "second"}, {"end": 2686.72, "start": 2685.8, "text": "part"}, {"end": 2687.0, "start": 2686.72, "text": "to"}, {"end": 2688.2, "start": 2687.0, "text": "find"}, {"end": 2688.48, "start": 2688.2, "text": "the"}, {"end": 2688.72, "start": 2688.48, "text": "peak"}, {"end": 2688.92, "start": 2688.72, "text": "in"}, {"end": 2689.16, "start": 2688.92, "text": "rho"}, {"end": 2689.36, "start": 2689.16, "text": "i,"}, {"end": 2689.48, "start": 2689.36, "text": "you"}, {"end": 2689.64, "start": 2689.48, "text": "might"}, {"end": 2689.96, "start": 2689.64, "text": "not"}, {"end": 2690.28, "start": 2689.96, "text": "have"}, {"end": 2690.48, "start": 2690.28, "text": "a"}, {"end": 2690.84, "start": 2690.48, "text": "column"}, {"end": 2691.12, "start": 2690.84, "text": "peak"}, {"end": 2691.36, "start": 2691.12, "text": "in."}, {"end": 2691.6, "start": 2691.36, "text": "There"}, {"end": 2692.08, "start": 2691.6, "text": "might"}, {"end": 2692.4, "start": 2692.08, "text": "not"}, {"end": 2692.64, "start": 2692.4, "text": "be"}, {"end": 2692.96, "start": 2692.64, "text": "a"}, {"end": 2693.08, "start": 2692.96, "text": "peak"}, {"end": 2693.24, "start": 2693.08, "text": "on"}, {"end": 2693.24, "start": 2693.24, "text": "the"}, {"end": 2694.08, "start": 2693.24, "text": "column"}, {"end": 2694.28, "start": 2694.08, "text": "anymore."}, {"end": 2694.6, "start": 2694.28, "text": "That's"}, {"end": 2695.96, "start": 2694.6, "text": "exactly"}, {"end": 2696.04, "start": 2695.96, "text": "correct."}, {"end": 2697.0, "start": 2696.04, "text": "So"}, {"end": 2697.48, "start": 2697.0, "text": "this"}, {"end": 2697.88, "start": 2697.48, "text": "algorithm"}, {"end": 2698.48, "start": 2697.88, "text": "is"}, {"end": 2699.96, "start": 2698.48, "text": "incorrect."}], "text": " If n equals m, then I have a couple of steps of log n, and I'm done. Am I done? No. Can someone tell me why I'm not done precisely? Yep. Because when you do the second part to find the peak in rho i, you might not have a column peak in. There might not be a peak on the column anymore. That's exactly correct. So this algorithm is incorrect."}, {"chunks": [{"end": 2700.2, "start": 2700.0, "text": "It"}, {"end": 2700.92, "start": 2700.2, "text": "doesn't"}, {"end": 2701.44, "start": 2700.92, "text": "work."}, {"end": 2702.56, "start": 2701.44, "text": "It's"}, {"end": 2703.12, "start": 2702.56, "text": "efficient"}, {"end": 2703.36, "start": 2703.12, "text": "but"}, {"end": 2704.48, "start": 2703.36, "text": "incorrect."}, {"end": 2705.0, "start": 2704.48, "text": "You"}, {"end": 2705.16, "start": 2705.0, "text": "want"}, {"end": 2706.08, "start": 2705.16, "text": "to"}, {"end": 2706.44, "start": 2706.08, "text": "be"}, {"end": 2707.36, "start": 2706.44, "text": "correct."}, {"end": 2707.68, "start": 2707.36, "text": "Being"}, {"end": 2708.28, "start": 2707.68, "text": "correct"}, {"end": 2708.88, "start": 2708.28, "text": "and"}, {"end": 2709.64, "start": 2708.88, "text": "inefficient"}, {"end": 2709.76, "start": 2709.64, "text": "is"}, {"end": 2711.16, "start": 2709.76, "text": "definitely"}, {"end": 2711.8, "start": 2711.16, "text": "better"}, {"end": 2713.32, "start": 2711.8, "text": "than"}, {"end": 2713.64, "start": 2713.32, "text": "being"}, {"end": 2714.28, "start": 2713.64, "text": "incorrect"}, {"end": 2714.52, "start": 2714.28, "text": "and"}, {"end": 2715.64, "start": 2714.52, "text": "efficient."}, {"end": 2716.08, "start": 2715.64, "text": "So"}, {"end": 2716.32, "start": 2716.08, "text": "this"}, {"end": 2716.56, "start": 2716.32, "text": "is"}, {"end": 2716.92, "start": 2716.56, "text": "an"}, {"end": 2717.32, "start": 2716.92, "text": "efficient"}, {"end": 2717.76, "start": 2717.32, "text": "algorithm"}, {"end": 2717.76, "start": 2717.76, "text": "in"}, {"end": 2717.96, "start": 2717.76, "text": "the"}, {"end": 2718.24, "start": 2717.96, "text": "sense"}, {"end": 2718.24, "start": 2718.24, "text": "that"}, {"end": 2718.24, "start": 2718.24, "text": "it"}, {"end": 2718.32, "start": 2718.24, "text": "would"}, {"end": 2718.88, "start": 2718.32, "text": "only"}, {"end": 2720.32, "start": 2718.88, "text": "take"}, {"end": 2720.64, "start": 2720.32, "text": "log"}, {"end": 2720.84, "start": 2720.64, "text": "n"}, {"end": 2721.28, "start": 2720.84, "text": "time."}, {"end": 2721.8, "start": 2721.28, "text": "But"}, {"end": 2721.8, "start": 2721.8, "text": "it"}, {"end": 2722.08, "start": 2721.8, "text": "doesn't"}, {"end": 2722.4, "start": 2722.08, "text": "work."}, {"end": 2722.68, "start": 2722.4, "text": "And"}, {"end": 2723.68, "start": 2722.68, "text": "I'll"}, {"end": 2723.68, "start": 2723.68, "text": "give"}, {"end": 2723.84, "start": 2723.68, "text": "you"}, {"end": 2724.36, "start": 2723.84, "text": "a"}, {"end": 2725.0, "start": 2724.36, "text": "simple"}, {"end": 2725.56, "start": 2725.0, "text": "example"}, {"end": 2726.72, "start": 2725.56, "text": "here"}, {"end": 2727.0, "start": 2726.72, "text": "where"}, {"end": 2727.0, "start": 2727.0, "text": "it"}, {"end": 2728.96, "start": 2727.0, "text": "doesn't"}, {"end": 2729.96, "start": 2728.96, "text": "work."}], "text": " It doesn't work. It's efficient but incorrect. You want to be correct. Being correct and inefficient is definitely better than being incorrect and efficient. So this is an efficient algorithm in the sense that it would only take log n time. But it doesn't work. And I'll give you a simple example here where it doesn't work."}, {"chunks": [{"end": 2732.52, "start": 2730.0, "text": "The"}, {"end": 2733.04, "start": 2732.52, "text": "problem"}, {"end": 2735.64, "start": 2733.04, "text": "is"}, {"end": 2735.84, "start": 2735.64, "text": "a"}, {"end": 2736.36, "start": 2735.84, "text": "2-D"}, {"end": 2736.92, "start": 2736.36, "text": "peak"}, {"end": 2738.56, "start": 2736.92, "text": "may"}, {"end": 2740.0, "start": 2738.56, "text": "not"}, {"end": 2741.88, "start": 2740.0, "text": "exist"}, {"end": 2742.6, "start": 2741.88, "text": "on"}, {"end": 2744.04, "start": 2742.6, "text": "rho"}, {"end": 2745.28, "start": 2744.04, "text": "i."}, {"end": 2746.12, "start": 2745.28, "text": "And"}, {"end": 2746.8, "start": 2746.12, "text": "here's"}, {"end": 2746.96, "start": 2746.8, "text": "an"}, {"end": 2748.0, "start": 2746.96, "text": "example"}, {"end": 2750.44, "start": 2748.0, "text": "of"}, {"end": 2753.6, "start": 2750.44, "text": "that."}, {"end": 2753.84, "start": 2753.6, "text": "Actually,"}, {"end": 2753.88, "start": 2753.84, "text": "this"}, {"end": 2754.08, "start": 2753.88, "text": "is"}, {"end": 2754.96, "start": 2754.08, "text": "exactly"}, {"end": 2756.32, "start": 2754.96, "text": "the"}, {"end": 2757.0, "start": 2756.32, "text": "example"}, {"end": 2757.84, "start": 2757.0, "text": "of"}, {"end": 2758.24, "start": 2757.84, "text": "that."}, {"end": 2758.8, "start": 2758.24, "text": "Let's"}, {"end": 2759.44, "start": 2758.8, "text": "say"}, {"end": 2759.56, "start": 2759.44, "text": "that"}, {"end": 2759.72, "start": 2759.56, "text": "I"}, {"end": 2759.88, "start": 2759.72, "text": "started"}, {"end": 2759.96, "start": 2759.88, "text": "with"}], "text": " The problem is a 2-D peak may not exist on rho i. And here's an example of that. Actually, this is exactly the example of that. Let's say that I started with"}, {"chunks": [{"end": 2761.16, "start": 2760.0, "text": "With"}, {"end": 2762.28, "start": 2761.16, "text": "this"}, {"end": 2762.64, "start": 2762.28, "text": "row,"}, {"end": 2763.48, "start": 2762.64, "text": "since"}, {"end": 2763.8, "start": 2763.48, "text": "I'm"}, {"end": 2764.04, "start": 2763.8, "text": "starting"}, {"end": 2764.08, "start": 2764.04, "text": "with"}, {"end": 2764.52, "start": 2764.08, "text": "the"}, {"end": 2765.0, "start": 2764.52, "text": "middle"}, {"end": 2765.48, "start": 2765.0, "text": "row,"}, {"end": 2765.96, "start": 2765.48, "text": "and"}, {"end": 2766.28, "start": 2765.96, "text": "I"}, {"end": 2766.52, "start": 2766.28, "text": "could"}, {"end": 2766.84, "start": 2766.52, "text": "start"}, {"end": 2766.96, "start": 2766.84, "text": "with"}, {"end": 2767.44, "start": 2766.96, "text": "this"}, {"end": 2767.72, "start": 2767.44, "text": "one"}, {"end": 2768.0, "start": 2767.72, "text": "or"}, {"end": 2768.8, "start": 2768.0, "text": "that"}, {"end": 2769.56, "start": 2768.8, "text": "one."}, {"end": 2769.68, "start": 2769.56, "text": "Let's"}, {"end": 2770.16, "start": 2769.68, "text": "say"}, {"end": 2770.52, "start": 2770.16, "text": "I"}, {"end": 2771.0, "start": 2770.52, "text": "started"}, {"end": 2771.6, "start": 2771.0, "text": "with"}, {"end": 2771.92, "start": 2771.6, "text": "that"}, {"end": 2772.24, "start": 2771.92, "text": "one."}, {"end": 2772.56, "start": 2772.24, "text": "I"}, {"end": 2773.52, "start": 2772.56, "text": "end"}, {"end": 2774.96, "start": 2773.52, "text": "up"}, {"end": 2775.52, "start": 2774.96, "text": "finding"}, {"end": 2775.8, "start": 2775.52, "text": "a"}, {"end": 2776.36, "start": 2775.8, "text": "peak."}, {"end": 2776.68, "start": 2776.36, "text": "And"}, {"end": 2776.68, "start": 2776.68, "text": "if"}, {"end": 2776.92, "start": 2776.68, "text": "this"}, {"end": 2777.44, "start": 2776.92, "text": "were"}, {"end": 2778.4, "start": 2777.44, "text": "10"}, {"end": 2778.56, "start": 2778.4, "text": "up"}, {"end": 2779.48, "start": 2778.56, "text": "here,"}, {"end": 2779.8, "start": 2779.48, "text": "I"}, {"end": 2780.56, "start": 2779.8, "text": "choose"}, {"end": 2782.0, "start": 2780.56, "text": "12"}, {"end": 2782.32, "start": 2782.0, "text": "as"}, {"end": 2782.8, "start": 2782.32, "text": "a"}, {"end": 2783.24, "start": 2782.8, "text": "peak."}, {"end": 2783.68, "start": 2783.24, "text": "And"}, {"end": 2783.88, "start": 2783.68, "text": "it's"}, {"end": 2784.04, "start": 2783.88, "text": "quite"}, {"end": 2784.32, "start": 2784.04, "text": "possible"}, {"end": 2784.52, "start": 2784.32, "text": "that"}, {"end": 2784.76, "start": 2784.52, "text": "I've"}, {"end": 2784.96, "start": 2784.76, "text": "returned"}, {"end": 2785.28, "start": 2784.96, "text": "12"}, {"end": 2785.56, "start": 2785.28, "text": "as"}, {"end": 2785.76, "start": 2785.56, "text": "a"}, {"end": 2786.2, "start": 2785.76, "text": "peak,"}, {"end": 2786.24, "start": 2786.2, "text": "even"}, {"end": 2786.4, "start": 2786.24, "text": "though"}, {"end": 2786.8, "start": 2786.4, "text": "19"}, {"end": 2787.04, "start": 2786.8, "text": "is"}, {"end": 2787.36, "start": 2787.04, "text": "bigger,"}, {"end": 2787.6, "start": 2787.36, "text": "because"}, {"end": 2788.12, "start": 2787.6, "text": "12"}, {"end": 2788.16, "start": 2788.12, "text": "is"}, {"end": 2788.28, "start": 2788.16, "text": "a"}, {"end": 2788.44, "start": 2788.28, "text": "peak,"}, {"end": 2788.72, "start": 2788.44, "text": "given"}, {"end": 2789.04, "start": 2788.72, "text": "10"}, {"end": 2789.04, "start": 2789.04, "text": "and"}, {"end": 2789.44, "start": 2789.04, "text": "11"}, {"end": 2789.44, "start": 2789.44, "text": "up"}, {"end": 2789.96, "start": 2789.44, "text": "here."}], "text": " With this row, since I'm starting with the middle row, and I could start with this one or that one. Let's say I started with that one. I end up finding a peak. And if this were 10 up here, I choose 12 as a peak. And it's quite possible that I've returned 12 as a peak, even though 19 is bigger, because 12 is a peak, given 10 and 11 up here."}, {"chunks": [{"end": 2790.32, "start": 2790.0, "text": "And"}, {"end": 2790.88, "start": 2790.32, "text": "then"}, {"end": 2790.96, "start": 2790.88, "text": "when"}, {"end": 2791.12, "start": 2790.96, "text": "I"}, {"end": 2791.48, "start": 2791.12, "text": "choose"}, {"end": 2791.72, "start": 2791.48, "text": "this"}, {"end": 2791.96, "start": 2791.72, "text": "particular"}, {"end": 2792.52, "start": 2791.96, "text": "row"}, {"end": 2793.04, "start": 2792.52, "text": "and"}, {"end": 2793.88, "start": 2793.04, "text": "I"}, {"end": 2794.16, "start": 2793.88, "text": "find"}, {"end": 2794.24, "start": 2794.16, "text": "a"}, {"end": 2794.52, "start": 2794.24, "text": "peak"}, {"end": 2794.6, "start": 2794.52, "text": "on"}, {"end": 2794.96, "start": 2794.6, "text": "this"}, {"end": 2795.32, "start": 2794.96, "text": "row,"}, {"end": 2795.52, "start": 2795.32, "text": "it"}, {"end": 2795.64, "start": 2795.52, "text": "would"}, {"end": 2795.68, "start": 2795.64, "text": "be"}, {"end": 2796.08, "start": 2795.68, "text": "14."}, {"end": 2796.08, "start": 2796.08, "text": "That"}, {"end": 2796.72, "start": 2796.08, "text": "is"}, {"end": 2797.0, "start": 2796.72, "text": "a"}, {"end": 2797.44, "start": 2797.0, "text": "1D"}, {"end": 2797.72, "start": 2797.44, "text": "peak"}, {"end": 2797.88, "start": 2797.72, "text": "on"}, {"end": 2798.12, "start": 2797.88, "text": "this"}, {"end": 2798.88, "start": 2798.12, "text": "row,"}, {"end": 2799.52, "start": 2798.88, "text": "but"}, {"end": 2799.84, "start": 2799.52, "text": "14"}, {"end": 2800.0, "start": 2799.84, "text": "is"}, {"end": 2800.44, "start": 2800.0, "text": "not"}, {"end": 2800.72, "start": 2800.44, "text": "a"}, {"end": 2800.92, "start": 2800.72, "text": "2D"}, {"end": 2801.8, "start": 2800.92, "text": "peak."}, {"end": 2802.76, "start": 2801.8, "text": "OK?"}, {"end": 2803.12, "start": 2802.76, "text": "So"}, {"end": 2803.24, "start": 2803.12, "text": "this"}, {"end": 2803.6, "start": 2803.24, "text": "particular"}, {"end": 2804.08, "start": 2803.6, "text": "example,"}, {"end": 2805.08, "start": 2804.08, "text": "14"}, {"end": 2805.32, "start": 2805.08, "text": "would"}, {"end": 2805.72, "start": 2805.32, "text": "return"}, {"end": 2807.56, "start": 2805.72, "text": "14."}, {"end": 2807.88, "start": 2807.56, "text": "And"}, {"end": 2808.2, "start": 2807.88, "text": "14"}, {"end": 2808.36, "start": 2808.2, "text": "is"}, {"end": 2809.0, "start": 2808.36, "text": "not"}, {"end": 2809.08, "start": 2809.0, "text": "a"}, {"end": 2809.4, "start": 2809.08, "text": "2D"}, {"end": 2809.88, "start": 2809.4, "text": "peak."}, {"end": 2810.2, "start": 2809.88, "text": "All"}, {"end": 2810.36, "start": 2810.2, "text": "right?"}, {"end": 2810.6, "start": 2810.36, "text": "You"}, {"end": 2811.08, "start": 2810.6, "text": "can"}, {"end": 2813.32, "start": 2811.08, "text": "collect"}, {"end": 2813.68, "start": 2813.32, "text": "your"}, {"end": 2813.96, "start": 2813.68, "text": "cushion"}, {"end": 2814.36, "start": 2813.96, "text": "after"}, {"end": 2814.72, "start": 2814.36, "text": "the"}, {"end": 2815.2, "start": 2814.72, "text": "class."}, {"end": 2817.08, "start": 2815.2, "text": "So"}, {"end": 2817.44, "start": 2817.08, "text": "not"}, {"end": 2819.48, "start": 2817.44, "text": "so"}, {"end": 2819.96, "start": 2819.48, "text": "good."}], "text": " And then when I choose this particular row and I find a peak on this row, it would be 14. That is a 1D peak on this row, but 14 is not a 2D peak. OK? So this particular example, 14 would return 14. And 14 is not a 2D peak. All right? You can collect your cushion after the class. So not so good."}, {"chunks": [{"end": 2821.28, "start": 2820.0, "text": "Looked"}, {"end": 2821.96, "start": 2821.28, "text": "like"}, {"end": 2822.16, "start": 2821.96, "text": "an"}, {"end": 2822.8, "start": 2822.16, "text": "efficient"}, {"end": 2823.08, "start": 2822.8, "text": "algorithm,"}, {"end": 2823.32, "start": 2823.08, "text": "but"}, {"end": 2824.04, "start": 2823.32, "text": "doesn't"}, {"end": 2824.32, "start": 2824.04, "text": "work."}, {"end": 2825.36, "start": 2824.32, "text": "So"}, {"end": 2825.76, "start": 2825.36, "text": "how"}, {"end": 2826.64, "start": 2825.76, "text": "can"}, {"end": 2827.16, "start": 2826.64, "text": "we"}, {"end": 2827.24, "start": 2827.16, "text": "get"}, {"end": 2827.28, "start": 2827.24, "text": "to"}, {"end": 2827.52, "start": 2827.28, "text": "something"}, {"end": 2827.76, "start": 2827.52, "text": "that"}, {"end": 2828.16, "start": 2827.76, "text": "actually"}, {"end": 2828.64, "start": 2828.16, "text": "works?"}, {"end": 2828.64, "start": 2828.64, "text": "So"}, {"end": 2829.2, "start": 2828.64, "text": "the"}, {"end": 2829.96, "start": 2829.2, "text": "last"}, {"end": 2831.32, "start": 2829.96, "text": "algorithm"}, {"end": 2833.0, "start": 2831.32, "text": "that"}, {"end": 2833.36, "start": 2833.0, "text": "I'm"}, {"end": 2833.4, "start": 2833.36, "text": "going"}, {"end": 2834.0, "start": 2833.4, "text": "to"}, {"end": 2834.04, "start": 2834.0, "text": "show"}, {"end": 2834.04, "start": 2834.04, "text": "you,"}, {"end": 2834.28, "start": 2834.04, "text": "and"}, {"end": 2834.6, "start": 2834.28, "text": "you'll"}, {"end": 2835.16, "start": 2834.6, "text": "see"}, {"end": 2835.6, "start": 2835.16, "text": "four"}, {"end": 2835.92, "start": 2835.6, "text": "different"}, {"end": 2836.4, "start": 2835.92, "text": "algorithms"}, {"end": 2836.56, "start": 2836.4, "text": "in"}, {"end": 2836.76, "start": 2836.56, "text": "your"}, {"end": 2836.88, "start": 2836.76, "text": "problem"}, {"end": 2838.16, "start": 2836.88, "text": "set"}, {"end": 2841.16, "start": 2838.16, "text": "that"}, {"end": 2841.28, "start": 2841.16, "text": "you'll"}, {"end": 2841.6, "start": 2841.28, "text": "have"}, {"end": 2841.96, "start": 2841.6, "text": "to"}, {"end": 2842.44, "start": 2841.96, "text": "analyze"}, {"end": 2842.56, "start": 2842.44, "text": "the"}, {"end": 2843.0, "start": 2842.56, "text": "complexity"}, {"end": 2843.28, "start": 2843.0, "text": "for"}, {"end": 2843.8, "start": 2843.28, "text": "and"}, {"end": 2844.92, "start": 2843.8, "text": "decide"}, {"end": 2845.8, "start": 2844.92, "text": "if"}, {"end": 2846.44, "start": 2845.8, "text": "they're"}, {"end": 2846.84, "start": 2846.44, "text": "efficient"}, {"end": 2847.64, "start": 2846.84, "text": "and"}, {"end": 2848.16, "start": 2847.64, "text": "if"}, {"end": 2848.32, "start": 2848.16, "text": "they're"}, {"end": 2849.96, "start": 2848.32, "text": "correct."}], "text": " Looked like an efficient algorithm, but doesn't work. So how can we get to something that actually works? So the last algorithm that I'm going to show you, and you'll see four different algorithms in your problem set that you'll have to analyze the complexity for and decide if they're efficient and if they're correct."}, {"chunks": [{"end": 2851.24, "start": 2850.0, "text": "A"}, {"end": 2851.76, "start": 2851.24, "text": "recursive"}, {"end": 2853.4, "start": 2851.76, "text": "version"}, {"end": 2854.8, "start": 2853.4, "text": "that"}, {"end": 2855.04, "start": 2854.8, "text": "is"}, {"end": 2856.2, "start": 2855.04, "text": "better"}, {"end": 2856.68, "start": 2856.2, "text": "than,"}, {"end": 2856.76, "start": 2856.68, "text": "in"}, {"end": 2857.08, "start": 2856.76, "text": "terms"}, {"end": 2857.12, "start": 2857.08, "text": "of"}, {"end": 2857.6, "start": 2857.12, "text": "complexity,"}, {"end": 2857.76, "start": 2857.6, "text": "than"}, {"end": 2857.96, "start": 2857.76, "text": "the"}, {"end": 2858.2, "start": 2857.96, "text": "greedy"}, {"end": 2858.64, "start": 2858.2, "text": "ascent"}, {"end": 2860.12, "start": 2858.64, "text": "algorithm."}, {"end": 2860.64, "start": 2860.12, "text": "And"}, {"end": 2860.8, "start": 2860.64, "text": "this"}, {"end": 2861.0, "start": 2860.8, "text": "one"}, {"end": 2861.44, "start": 2861.0, "text": "works."}, {"end": 2861.76, "start": 2861.44, "text": "So"}, {"end": 2863.0, "start": 2861.76, "text": "what"}, {"end": 2863.44, "start": 2863.0, "text": "I'm"}, {"end": 2864.28, "start": 2863.44, "text": "going"}, {"end": 2864.44, "start": 2864.28, "text": "to"}, {"end": 2864.76, "start": 2864.44, "text": "do"}, {"end": 2865.2, "start": 2864.76, "text": "is"}, {"end": 2865.4, "start": 2865.2, "text": "pick"}, {"end": 2865.52, "start": 2865.4, "text": "a"}, {"end": 2865.96, "start": 2865.52, "text": "middle"}, {"end": 2866.84, "start": 2865.96, "text": "column,"}, {"end": 2869.72, "start": 2866.84, "text": "j"}, {"end": 2870.28, "start": 2869.72, "text": "equals"}, {"end": 2870.44, "start": 2870.28, "text": "m"}, {"end": 2870.68, "start": 2870.44, "text": "over"}, {"end": 2871.12, "start": 2870.68, "text": "2"}, {"end": 2871.24, "start": 2871.12, "text": "as"}, {"end": 2874.0, "start": 2871.24, "text": "before."}, {"end": 2874.36, "start": 2874.0, "text": "I'm"}, {"end": 2875.0, "start": 2874.36, "text": "going"}, {"end": 2876.48, "start": 2875.0, "text": "to"}, {"end": 2876.64, "start": 2876.48, "text": "find"}, {"end": 2877.04, "start": 2876.64, "text": "the"}, {"end": 2877.48, "start": 2877.04, "text": "global"}, {"end": 2879.96, "start": 2877.48, "text": "maximum"}], "text": " A recursive version that is better than, in terms of complexity, than the greedy ascent algorithm. And this one works. So what I'm going to do is pick a middle column, j equals m over 2 as before. I'm going to find the global maximum"}, {"chunks": [{"end": 2881.4, "start": 2880.0, "text": "on"}, {"end": 2881.84, "start": 2881.4, "text": "column"}, {"end": 2882.04, "start": 2881.84, "text": "j."}, {"end": 2884.48, "start": 2882.04, "text": "And"}, {"end": 2885.32, "start": 2884.48, "text": "that's"}, {"end": 2885.68, "start": 2885.32, "text": "going"}, {"end": 2885.92, "start": 2885.68, "text": "to"}, {"end": 2886.24, "start": 2885.92, "text": "be"}, {"end": 2886.52, "start": 2886.24, "text": "at"}, {"end": 2886.92, "start": 2886.52, "text": "ij."}, {"end": 2889.56, "start": 2886.92, "text": "I'm"}, {"end": 2889.84, "start": 2889.56, "text": "going"}, {"end": 2890.0, "start": 2889.84, "text": "to"}, {"end": 2890.64, "start": 2890.0, "text": "compare"}, {"end": 2892.76, "start": 2890.64, "text": "i"}, {"end": 2893.4, "start": 2892.76, "text": "comma"}, {"end": 2893.76, "start": 2893.4, "text": "j"}, {"end": 2894.56, "start": 2893.76, "text": "minus"}, {"end": 2896.12, "start": 2894.56, "text": "1,"}, {"end": 2896.36, "start": 2896.12, "text": "i"}, {"end": 2896.68, "start": 2896.36, "text": "comma"}, {"end": 2897.4, "start": 2896.68, "text": "j,"}, {"end": 2897.76, "start": 2897.4, "text": "and"}, {"end": 2897.88, "start": 2897.76, "text": "ij"}, {"end": 2899.04, "start": 2897.88, "text": "plus"}, {"end": 2899.24, "start": 2899.04, "text": "1,"}, {"end": 2899.56, "start": 2899.24, "text": "which"}, {"end": 2899.56, "start": 2899.56, "text": "means"}, {"end": 2899.76, "start": 2899.56, "text": "that"}, {"end": 2900.04, "start": 2899.76, "text": "once"}, {"end": 2900.44, "start": 2900.04, "text": "I've"}, {"end": 2900.96, "start": 2900.44, "text": "found"}, {"end": 2901.24, "start": 2900.96, "text": "the"}, {"end": 2902.08, "start": 2901.24, "text": "maximum"}, {"end": 2902.08, "start": 2902.08, "text": "in"}, {"end": 2902.32, "start": 2902.08, "text": "this"}, {"end": 2903.68, "start": 2902.32, "text": "row,"}, {"end": 2904.16, "start": 2903.68, "text": "I'm"}, {"end": 2904.76, "start": 2904.16, "text": "going"}, {"end": 2904.92, "start": 2904.76, "text": "to"}, {"end": 2905.2, "start": 2904.92, "text": "look"}, {"end": 2905.36, "start": 2905.2, "text": "to"}, {"end": 2905.88, "start": 2905.36, "text": "the"}, {"end": 2906.04, "start": 2905.88, "text": "left"}, {"end": 2906.12, "start": 2906.04, "text": "and"}, {"end": 2907.8, "start": 2906.12, "text": "the"}, {"end": 2908.04, "start": 2907.8, "text": "right"}, {"end": 2908.32, "start": 2908.04, "text": "and"}, {"end": 2909.04, "start": 2908.32, "text": "compare."}, {"end": 2909.64, "start": 2909.04, "text": "I'm"}, {"end": 2909.84, "start": 2909.64, "text": "going"}, {"end": 2909.84, "start": 2909.84, "text": "to"}, {"end": 2909.96, "start": 2909.84, "text": "pick."}], "text": " on column j. And that's going to be at ij. I'm going to compare i comma j minus 1, i comma j, and ij plus 1, which means that once I've found the maximum in this row, I'm going to look to the left and the right and compare. I'm going to pick."}, {"chunks": [{"end": 2910.16, "start": 2910.0, "text": "the"}, {"end": 2910.44, "start": 2910.16, "text": "left"}, {"end": 2911.68, "start": 2910.44, "text": "columns"}, {"end": 2911.96, "start": 2911.68, "text": "if"}, {"end": 2913.04, "start": 2911.96, "text": "i"}, {"end": 2913.44, "start": 2913.04, "text": "comma"}, {"end": 2914.52, "start": 2913.44, "text": "j"}, {"end": 2915.56, "start": 2914.52, "text": "minus"}, {"end": 2916.68, "start": 2915.56, "text": "1"}, {"end": 2916.88, "start": 2916.68, "text": "is"}, {"end": 2917.16, "start": 2916.88, "text": "greater"}, {"end": 2918.72, "start": 2917.16, "text": "than"}, {"end": 2919.6, "start": 2918.72, "text": "i"}, {"end": 2920.88, "start": 2919.6, "text": "comma"}, {"end": 2921.08, "start": 2920.88, "text": "j."}, {"end": 2921.2, "start": 2921.08, "text": "And"}, {"end": 2923.12, "start": 2921.2, "text": "similarly"}, {"end": 2923.52, "start": 2923.12, "text": "for"}, {"end": 2924.56, "start": 2923.52, "text": "the"}, {"end": 2928.56, "start": 2924.56, "text": "right."}, {"end": 2929.48, "start": 2928.56, "text": "And"}, {"end": 2929.8, "start": 2929.48, "text": "if"}, {"end": 2930.08, "start": 2929.8, "text": "in"}, {"end": 2931.32, "start": 2930.08, "text": "fact"}, {"end": 2932.36, "start": 2931.32, "text": "either"}, {"end": 2932.68, "start": 2932.36, "text": "of"}, {"end": 2933.24, "start": 2932.68, "text": "these"}, {"end": 2935.12, "start": 2933.24, "text": "two"}, {"end": 2935.64, "start": 2935.12, "text": "conditions"}, {"end": 2935.96, "start": 2935.64, "text": "don't"}, {"end": 2936.92, "start": 2935.96, "text": "fire,"}, {"end": 2937.56, "start": 2936.92, "text": "and"}, {"end": 2938.48, "start": 2937.56, "text": "what"}, {"end": 2938.72, "start": 2938.48, "text": "I"}, {"end": 2938.72, "start": 2938.72, "text": "have"}, {"end": 2938.72, "start": 2938.72, "text": "is"}, {"end": 2938.72, "start": 2938.72, "text": "i"}, {"end": 2939.04, "start": 2938.72, "text": "comma"}, {"end": 2939.96, "start": 2939.04, "text": "j,"}], "text": " the left columns if i comma j minus 1 is greater than i comma j. And similarly for the right. And if in fact either of these two conditions don't fire, and what I have is i comma j,"}, {"chunks": [{"end": 2940.16, "start": 2940.0, "text": "is"}, {"end": 2940.44, "start": 2940.16, "text": "greater"}, {"end": 2941.36, "start": 2940.44, "text": "than"}, {"end": 2941.52, "start": 2941.36, "text": "or"}, {"end": 2941.52, "start": 2941.52, "text": "equal"}, {"end": 2942.36, "start": 2941.52, "text": "to"}, {"end": 2942.52, "start": 2942.36, "text": "i"}, {"end": 2942.84, "start": 2942.52, "text": "comma"}, {"end": 2943.04, "start": 2942.84, "text": "j"}, {"end": 2943.36, "start": 2943.04, "text": "minus"}, {"end": 2943.68, "start": 2943.36, "text": "1"}, {"end": 2944.32, "start": 2943.68, "text": "and"}, {"end": 2944.64, "start": 2944.32, "text": "i"}, {"end": 2944.96, "start": 2944.64, "text": "comma"}, {"end": 2945.16, "start": 2944.96, "text": "j"}, {"end": 2945.4, "start": 2945.16, "text": "plus"}, {"end": 2946.32, "start": 2945.4, "text": "1,"}, {"end": 2946.76, "start": 2946.32, "text": "then"}, {"end": 2947.08, "start": 2946.76, "text": "I'm"}, {"end": 2947.56, "start": 2947.08, "text": "done."}, {"end": 2947.88, "start": 2947.56, "text": "Just"}, {"end": 2948.28, "start": 2947.88, "text": "like"}, {"end": 2949.52, "start": 2948.28, "text": "I"}, {"end": 2950.08, "start": 2949.52, "text": "had"}, {"end": 2950.76, "start": 2950.08, "text": "for"}, {"end": 2951.04, "start": 2950.76, "text": "the"}, {"end": 2951.4, "start": 2951.04, "text": "1D"}, {"end": 2952.72, "start": 2951.4, "text": "version,"}, {"end": 2953.32, "start": 2952.72, "text": "if"}, {"end": 2954.16, "start": 2953.32, "text": "i"}, {"end": 2954.76, "start": 2954.16, "text": "comma"}, {"end": 2955.72, "start": 2954.76, "text": "j"}, {"end": 2955.88, "start": 2955.72, "text": "is"}, {"end": 2956.6, "start": 2955.88, "text": "greater"}, {"end": 2956.88, "start": 2956.6, "text": "than"}, {"end": 2957.08, "start": 2956.88, "text": "or"}, {"end": 2957.36, "start": 2957.08, "text": "equal"}, {"end": 2957.96, "start": 2957.36, "text": "to"}, {"end": 2958.32, "start": 2957.96, "text": "i"}, {"end": 2959.28, "start": 2958.32, "text": "comma"}, {"end": 2959.68, "start": 2959.28, "text": "j"}, {"end": 2960.16, "start": 2959.68, "text": "minus"}, {"end": 2960.64, "start": 2960.16, "text": "1"}, {"end": 2960.96, "start": 2960.64, "text": "and"}, {"end": 2961.2, "start": 2960.96, "text": "i"}, {"end": 2962.84, "start": 2961.2, "text": "comma"}, {"end": 2963.08, "start": 2962.84, "text": "j"}, {"end": 2963.84, "start": 2963.08, "text": "plus"}, {"end": 2964.24, "start": 2963.84, "text": "1,"}, {"end": 2964.6, "start": 2964.24, "text": "that"}, {"end": 2965.2, "start": 2964.6, "text": "implies"}, {"end": 2966.32, "start": 2965.2, "text": "ij"}, {"end": 2966.64, "start": 2966.32, "text": "is"}, {"end": 2967.0, "start": 2966.64, "text": "a"}, {"end": 2967.56, "start": 2967.0, "text": "2d"}, {"end": 2969.4, "start": 2967.56, "text": "peak."}, {"end": 2969.96, "start": 2969.4, "text": "OK?"}], "text": " is greater than or equal to i comma j minus 1 and i comma j plus 1, then I'm done. Just like I had for the 1D version, if i comma j is greater than or equal to i comma j minus 1 and i comma j plus 1, that implies ij is a 2d peak. OK?"}, {"chunks": [{"end": 2970.04, "start": 2970.0, "text": "The"}, {"end": 2970.44, "start": 2970.04, "text": "case"}, {"end": 2970.52, "start": 2970.44, "text": "is"}, {"end": 2971.16, "start": 2970.52, "text": "because"}, {"end": 2971.88, "start": 2971.16, "text": "i"}, {"end": 2972.2, "start": 2971.88, "text": "comma"}, {"end": 2972.92, "start": 2972.2, "text": "j"}, {"end": 2973.08, "start": 2972.92, "text": "was"}, {"end": 2973.2, "start": 2973.08, "text": "the"}, {"end": 2973.88, "start": 2973.2, "text": "maximum"}, {"end": 2974.92, "start": 2973.88, "text": "element"}, {"end": 2975.0, "start": 2974.92, "text": "in"}, {"end": 2975.2, "start": 2975.0, "text": "that"}, {"end": 2975.96, "start": 2975.2, "text": "column."}, {"end": 2976.16, "start": 2975.96, "text": "So"}, {"end": 2976.48, "start": 2976.16, "text": "you"}, {"end": 2976.84, "start": 2976.48, "text": "know"}, {"end": 2976.84, "start": 2976.84, "text": "that"}, {"end": 2976.84, "start": 2976.84, "text": "you've"}, {"end": 2977.24, "start": 2976.84, "text": "compared"}, {"end": 2977.24, "start": 2977.24, "text": "it"}, {"end": 2978.12, "start": 2977.24, "text": "to"}, {"end": 2978.44, "start": 2978.12, "text": "all"}, {"end": 2978.44, "start": 2978.44, "text": "of"}, {"end": 2978.8, "start": 2978.44, "text": "the"}, {"end": 2979.2, "start": 2978.8, "text": "adjacent"}, {"end": 2979.64, "start": 2979.2, "text": "elements"}, {"end": 2980.0, "start": 2979.64, "text": "looking"}, {"end": 2980.28, "start": 2980.0, "text": "up"}, {"end": 2980.48, "start": 2980.28, "text": "and"}, {"end": 2980.76, "start": 2980.48, "text": "looking"}, {"end": 2981.08, "start": 2980.76, "text": "down."}, {"end": 2981.44, "start": 2981.08, "text": "That's"}, {"end": 2981.68, "start": 2981.44, "text": "the"}, {"end": 2982.04, "start": 2981.68, "text": "maximum"}, {"end": 2982.16, "start": 2982.04, "text": "element."}, {"end": 2982.4, "start": 2982.16, "text": "Now"}, {"end": 2982.52, "start": 2982.4, "text": "you've"}, {"end": 2982.56, "start": 2982.52, "text": "looked"}, {"end": 2982.96, "start": 2982.56, "text": "at"}, {"end": 2983.32, "start": 2982.96, "text": "the"}, {"end": 2983.64, "start": 2983.32, "text": "left"}, {"end": 2983.96, "start": 2983.64, "text": "and"}, {"end": 2984.16, "start": 2983.96, "text": "the"}, {"end": 2984.6, "start": 2984.16, "text": "right."}, {"end": 2985.16, "start": 2984.6, "text": "And"}, {"end": 2985.4, "start": 2985.16, "text": "in"}, {"end": 2985.68, "start": 2985.4, "text": "fact,"}, {"end": 2985.84, "start": 2985.68, "text": "it's"}, {"end": 2986.08, "start": 2985.84, "text": "greater"}, {"end": 2986.48, "start": 2986.08, "text": "than"}, {"end": 2986.6, "start": 2986.48, "text": "or"}, {"end": 2986.6, "start": 2986.6, "text": "equal"}, {"end": 2986.72, "start": 2986.6, "text": "to"}, {"end": 2987.04, "start": 2986.72, "text": "the"}, {"end": 2987.16, "start": 2987.04, "text": "elements"}, {"end": 2987.28, "start": 2987.16, "text": "on"}, {"end": 2987.48, "start": 2987.28, "text": "the"}, {"end": 2987.68, "start": 2987.48, "text": "left"}, {"end": 2987.84, "start": 2987.68, "text": "and"}, {"end": 2988.28, "start": 2987.84, "text": "the"}, {"end": 2988.64, "start": 2988.28, "text": "right."}, {"end": 2988.64, "start": 2988.64, "text": "And"}, {"end": 2988.76, "start": 2988.64, "text": "so"}, {"end": 2989.6, "start": 2988.76, "text": "therefore,"}, {"end": 2989.92, "start": 2989.6, "text": "it's"}, {"end": 2989.92, "start": 2989.92, "text": "a"}, {"end": 2990.2, "start": 2989.92, "text": "2d"}, {"end": 2991.24, "start": 2990.2, "text": "peak."}, {"end": 2992.24, "start": 2991.24, "text": "OK?"}, {"end": 2992.76, "start": 2992.24, "text": "So"}, {"end": 2992.88, "start": 2992.76, "text": "in"}, {"end": 2993.08, "start": 2992.88, "text": "this"}, {"end": 2994.08, "start": 2993.08, "text": "case,"}, {"end": 2994.2, "start": 2994.08, "text": "when"}, {"end": 2994.28, "start": 2994.2, "text": "you"}, {"end": 2994.32, "start": 2994.28, "text": "pick"}, {"end": 2994.52, "start": 2994.32, "text": "the"}, {"end": 2995.2, "start": 2994.52, "text": "left"}, {"end": 2996.0, "start": 2995.2, "text": "or"}, {"end": 2996.76, "start": 2996.0, "text": "the"}, {"end": 2996.84, "start": 2996.76, "text": "right"}, {"end": 2997.8, "start": 2996.84, "text": "columns,"}, {"end": 2997.96, "start": 2997.8, "text": "you'll"}, {"end": 2998.12, "start": 2997.96, "text": "pick"}, {"end": 2998.44, "start": 2998.12, "text": "one"}, {"end": 2998.72, "start": 2998.44, "text": "of"}, {"end": 2998.76, "start": 2998.72, "text": "them,"}, {"end": 2998.88, "start": 2998.76, "text": "you're"}, {"end": 2999.28, "start": 2998.88, "text": "going"}, {"end": 2999.52, "start": 2999.28, "text": "to"}, {"end": 2999.96, "start": 2999.52, "text": "solve"}], "text": " The case is because i comma j was the maximum element in that column. So you know that you've compared it to all of the adjacent elements looking up and looking down. That's the maximum element. Now you've looked at the left and the right. And in fact, it's greater than or equal to the elements on the left and the right. And so therefore, it's a 2d peak. OK? So in this case, when you pick the left or the right columns, you'll pick one of them, you're going to solve"}, {"chunks": [{"end": 3000.52, "start": 3000.0, "text": "of"}, {"end": 3001.76, "start": 3000.52, "text": "the"}, {"end": 3001.96, "start": 3001.76, "text": "new"}, {"end": 3003.16, "start": 3001.96, "text": "problem"}, {"end": 3003.36, "start": 3003.16, "text": "with"}, {"end": 3005.4, "start": 3003.36, "text": "half"}, {"end": 3006.96, "start": 3005.4, "text": "the"}, {"end": 3007.44, "start": 3006.96, "text": "number"}, {"end": 3007.68, "start": 3007.44, "text": "of"}, {"end": 3008.76, "start": 3007.68, "text": "columns."}, {"end": 3010.0, "start": 3008.76, "text": "All"}, {"end": 3012.72, "start": 3010.0, "text": "right?"}, {"end": 3013.72, "start": 3012.72, "text": "And"}, {"end": 3014.72, "start": 3013.72, "text": "again,"}, {"end": 3016.44, "start": 3014.72, "text": "you"}, {"end": 3016.88, "start": 3016.44, "text": "have"}, {"end": 3018.0, "start": 3016.88, "text": "to"}, {"end": 3018.4, "start": 3018.0, "text": "go"}, {"end": 3019.36, "start": 3018.4, "text": "through"}, {"end": 3019.6, "start": 3019.36, "text": "an"}, {"end": 3020.52, "start": 3019.6, "text": "analysis"}, {"end": 3020.6, "start": 3020.52, "text": "or"}, {"end": 3021.2, "start": 3020.6, "text": "an"}, {"end": 3021.8, "start": 3021.2, "text": "argument"}, {"end": 3021.92, "start": 3021.8, "text": "to"}, {"end": 3022.08, "start": 3021.92, "text": "make"}, {"end": 3022.36, "start": 3022.08, "text": "sure"}, {"end": 3022.96, "start": 3022.36, "text": "that"}, {"end": 3023.44, "start": 3022.96, "text": "this"}, {"end": 3023.68, "start": 3023.44, "text": "algorithm"}, {"end": 3023.68, "start": 3023.68, "text": "is"}, {"end": 3025.0, "start": 3023.68, "text": "correct."}, {"end": 3025.8, "start": 3025.0, "text": "But"}, {"end": 3026.84, "start": 3025.8, "text": "it's"}, {"end": 3027.32, "start": 3026.84, "text": "intuitively"}, {"end": 3027.88, "start": 3027.32, "text": "correct"}, {"end": 3028.2, "start": 3027.88, "text": "simply"}, {"end": 3028.44, "start": 3028.2, "text": "because"}, {"end": 3028.56, "start": 3028.44, "text": "it"}, {"end": 3029.96, "start": 3028.56, "text": "matches"}], "text": " of the new problem with half the number of columns. All right? And again, you have to go through an analysis or an argument to make sure that this algorithm is correct. But it's intuitively correct simply because it matches"}, {"chunks": [{"end": 3030.52, "start": 3030.0, "text": "1D"}, {"end": 3031.48, "start": 3030.52, "text": "version"}, {"end": 3031.72, "start": 3031.48, "text": "much"}, {"end": 3031.88, "start": 3031.72, "text": "more"}, {"end": 3032.4, "start": 3031.88, "text": "closely."}, {"end": 3033.2, "start": 3032.4, "text": "And"}, {"end": 3033.56, "start": 3033.2, "text": "you"}, {"end": 3034.52, "start": 3033.56, "text": "also"}, {"end": 3035.04, "start": 3034.52, "text": "have"}, {"end": 3035.08, "start": 3035.04, "text": "your"}, {"end": 3035.4, "start": 3035.08, "text": "condition"}, {"end": 3035.56, "start": 3035.4, "text": "where"}, {"end": 3035.76, "start": 3035.56, "text": "you"}, {"end": 3036.08, "start": 3035.76, "text": "break"}, {"end": 3037.36, "start": 3036.08, "text": "away"}, {"end": 3037.56, "start": 3037.36, "text": "right"}, {"end": 3037.84, "start": 3037.56, "text": "here,"}, {"end": 3038.32, "start": 3037.84, "text": "where"}, {"end": 3038.32, "start": 3038.32, "text": "you"}, {"end": 3038.44, "start": 3038.32, "text": "have"}, {"end": 3038.92, "start": 3038.44, "text": "a"}, {"end": 3039.2, "start": 3038.92, "text": "2D"}, {"end": 3039.56, "start": 3039.2, "text": "peak,"}, {"end": 3039.92, "start": 3039.56, "text": "just"}, {"end": 3040.48, "start": 3039.92, "text": "like"}, {"end": 3041.12, "start": 3040.48, "text": "the"}, {"end": 3041.64, "start": 3041.12, "text": "1D"}, {"end": 3041.96, "start": 3041.64, "text": "version."}, {"end": 3042.24, "start": 3041.96, "text": "And"}, {"end": 3042.32, "start": 3042.24, "text": "what"}, {"end": 3042.48, "start": 3042.32, "text": "you've"}, {"end": 3042.6, "start": 3042.48, "text": "done"}, {"end": 3042.6, "start": 3042.6, "text": "is"}, {"end": 3042.64, "start": 3042.6, "text": "break"}, {"end": 3042.92, "start": 3042.64, "text": "this"}, {"end": 3043.56, "start": 3042.92, "text": "matrix"}, {"end": 3043.92, "start": 3043.56, "text": "up"}, {"end": 3044.52, "start": 3043.92, "text": "into"}, {"end": 3045.36, "start": 3044.52, "text": "half"}, {"end": 3045.76, "start": 3045.36, "text": "the"}, {"end": 3046.2, "start": 3045.76, "text": "size."}, {"end": 3046.68, "start": 3046.2, "text": "And"}, {"end": 3047.0, "start": 3046.68, "text": "that's"}, {"end": 3048.12, "start": 3047.0, "text": "essentially"}, {"end": 3048.64, "start": 3048.12, "text": "why"}, {"end": 3049.12, "start": 3048.64, "text": "this"}, {"end": 3050.88, "start": 3049.12, "text": "algorithm"}, {"end": 3051.84, "start": 3050.88, "text": "works."}, {"end": 3054.72, "start": 3051.84, "text": "When"}, {"end": 3055.36, "start": 3054.72, "text": "you"}, {"end": 3056.2, "start": 3055.36, "text": "have"}, {"end": 3057.0, "start": 3056.2, "text": "a"}, {"end": 3057.44, "start": 3057.0, "text": "single"}, {"end": 3059.96, "start": 3057.44, "text": "column,"}], "text": " 1D version much more closely. And you also have your condition where you break away right here, where you have a 2D peak, just like the 1D version. And what you've done is break this matrix up into half the size. And that's essentially why this algorithm works. When you have a single column,"}, {"chunks": [{"end": 3061.0, "start": 3060.0, "text": "Find"}, {"end": 3063.04, "start": 3061.0, "text": "the"}, {"end": 3063.4, "start": 3063.04, "text": "global"}, {"end": 3066.76, "start": 3063.4, "text": "maximum."}, {"end": 3067.44, "start": 3066.76, "text": "And"}, {"end": 3068.4, "start": 3067.44, "text": "you're"}, {"end": 3069.84, "start": 3068.4, "text": "done."}, {"end": 3070.08, "start": 3069.84, "text": "So"}, {"end": 3070.44, "start": 3070.08, "text": "that's"}, {"end": 3071.32, "start": 3070.44, "text": "the"}, {"end": 3071.64, "start": 3071.32, "text": "base"}, {"end": 3072.52, "start": 3071.64, "text": "case."}, {"end": 3072.76, "start": 3072.52, "text": "So"}, {"end": 3072.88, "start": 3072.76, "text": "let"}, {"end": 3073.4, "start": 3072.88, "text": "me"}, {"end": 3073.56, "start": 3073.4, "text": "end"}, {"end": 3073.88, "start": 3073.56, "text": "with"}, {"end": 3074.04, "start": 3073.88, "text": "just"}, {"end": 3074.32, "start": 3074.04, "text": "writing"}, {"end": 3074.6, "start": 3074.32, "text": "out"}, {"end": 3074.88, "start": 3074.6, "text": "what"}, {"end": 3075.68, "start": 3074.88, "text": "the"}, {"end": 3076.28, "start": 3075.68, "text": "recurrence"}, {"end": 3076.68, "start": 3076.28, "text": "relation"}, {"end": 3076.84, "start": 3076.68, "text": "for"}, {"end": 3077.0, "start": 3076.84, "text": "the"}, {"end": 3077.36, "start": 3077.0, "text": "complexity"}, {"end": 3077.48, "start": 3077.36, "text": "of"}, {"end": 3077.76, "start": 3077.48, "text": "this"}, {"end": 3078.44, "start": 3077.76, "text": "is"}, {"end": 3078.6, "start": 3078.44, "text": "and"}, {"end": 3079.28, "start": 3078.6, "text": "argue"}, {"end": 3079.84, "start": 3079.28, "text": "what"}, {"end": 3080.36, "start": 3079.84, "text": "the"}, {"end": 3080.68, "start": 3080.36, "text": "overall"}, {"end": 3080.96, "start": 3080.68, "text": "complexity"}, {"end": 3081.52, "start": 3080.96, "text": "of"}, {"end": 3081.96, "start": 3081.52, "text": "this"}, {"end": 3082.56, "start": 3081.96, "text": "algorithm"}, {"end": 3085.0, "start": 3082.56, "text": "is."}, {"end": 3085.52, "start": 3085.0, "text": "And"}, {"end": 3086.2, "start": 3085.52, "text": "then"}, {"end": 3086.44, "start": 3086.2, "text": "I'll"}, {"end": 3086.76, "start": 3086.44, "text": "give"}, {"end": 3088.0, "start": 3086.76, "text": "you"}, {"end": 3088.48, "start": 3088.0, "text": "the"}, {"end": 3089.72, "start": 3088.48, "text": "bad"}, {"end": 3089.96, "start": 3089.72, "text": "news."}], "text": " Find the global maximum. And you're done. So that's the base case. So let me end with just writing out what the recurrence relation for the complexity of this is and argue what the overall complexity of this algorithm is. And then I'll give you the bad news."}, {"chunks": [{"end": 3090.88, "start": 3090.0, "text": "All"}, {"end": 3091.24, "start": 3090.88, "text": "right."}, {"end": 3091.96, "start": 3091.24, "text": "So"}, {"end": 3092.2, "start": 3091.96, "text": "overall,"}, {"end": 3092.4, "start": 3092.2, "text": "what"}, {"end": 3092.4, "start": 3092.4, "text": "you"}, {"end": 3093.36, "start": 3092.4, "text": "have"}, {"end": 3093.76, "start": 3093.36, "text": "is"}, {"end": 3094.16, "start": 3093.76, "text": "you"}, {"end": 3094.52, "start": 3094.16, "text": "have"}, {"end": 3094.88, "start": 3094.52, "text": "something"}, {"end": 3095.52, "start": 3094.88, "text": "like"}, {"end": 3095.88, "start": 3095.52, "text": "t"}, {"end": 3096.16, "start": 3095.88, "text": "of"}, {"end": 3096.36, "start": 3096.16, "text": "nm"}, {"end": 3096.76, "start": 3096.36, "text": "equals"}, {"end": 3097.08, "start": 3096.76, "text": "t"}, {"end": 3097.32, "start": 3097.08, "text": "of"}, {"end": 3098.2, "start": 3097.32, "text": "n"}, {"end": 3098.56, "start": 3098.2, "text": "m"}, {"end": 3098.92, "start": 3098.56, "text": "over"}, {"end": 3099.36, "start": 3098.92, "text": "2"}, {"end": 3101.04, "start": 3099.36, "text": "plus"}, {"end": 3101.48, "start": 3101.04, "text": "theta"}, {"end": 3101.64, "start": 3101.48, "text": "n."}, {"end": 3101.68, "start": 3101.64, "text": "Why"}, {"end": 3102.08, "start": 3101.68, "text": "is"}, {"end": 3102.52, "start": 3102.08, "text": "that?"}, {"end": 3103.04, "start": 3102.52, "text": "Well,"}, {"end": 3103.36, "start": 3103.04, "text": "n"}, {"end": 3103.6, "start": 3103.36, "text": "is"}, {"end": 3104.16, "start": 3103.6, "text": "the"}, {"end": 3104.4, "start": 3104.16, "text": "number"}, {"end": 3104.84, "start": 3104.4, "text": "of"}, {"end": 3105.32, "start": 3104.84, "text": "rows."}, {"end": 3105.32, "start": 3105.32, "text": "m"}, {"end": 3105.32, "start": 3105.32, "text": "is"}, {"end": 3105.64, "start": 3105.32, "text": "the"}, {"end": 3105.84, "start": 3105.64, "text": "number"}, {"end": 3106.0, "start": 3105.84, "text": "of"}, {"end": 3107.2, "start": 3106.0, "text": "columns."}, {"end": 3107.8, "start": 3107.2, "text": "In"}, {"end": 3108.24, "start": 3107.8, "text": "one"}, {"end": 3109.24, "start": 3108.24, "text": "case,"}, {"end": 3109.24, "start": 3109.24, "text": "you"}, {"end": 3109.56, "start": 3109.24, "text": "will"}, {"end": 3110.4, "start": 3109.56, "text": "be"}, {"end": 3110.76, "start": 3110.4, "text": "breaking"}, {"end": 3111.04, "start": 3110.76, "text": "things"}, {"end": 3111.48, "start": 3111.04, "text": "down"}, {"end": 3112.08, "start": 3111.48, "text": "into"}, {"end": 3112.4, "start": 3112.08, "text": "half"}, {"end": 3112.56, "start": 3112.4, "text": "the"}, {"end": 3112.72, "start": 3112.56, "text": "number"}, {"end": 3112.72, "start": 3112.72, "text": "of"}, {"end": 3113.2, "start": 3112.72, "text": "columns,"}, {"end": 3113.28, "start": 3113.2, "text": "which"}, {"end": 3113.4, "start": 3113.28, "text": "is"}, {"end": 3113.52, "start": 3113.4, "text": "m"}, {"end": 3113.76, "start": 3113.52, "text": "over"}, {"end": 3113.76, "start": 3113.76, "text": "2."}, {"end": 3113.76, "start": 3113.76, "text": "And"}, {"end": 3113.76, "start": 3113.76, "text": "in"}, {"end": 3113.76, "start": 3113.76, "text": "order"}, {"end": 3114.12, "start": 3113.76, "text": "to"}, {"end": 3114.88, "start": 3114.12, "text": "find"}, {"end": 3115.48, "start": 3114.88, "text": "the"}, {"end": 3116.08, "start": 3115.48, "text": "global"}, {"end": 3116.72, "start": 3116.08, "text": "maximum,"}, {"end": 3117.64, "start": 3116.72, "text": "you'll"}, {"end": 3117.76, "start": 3117.64, "text": "be"}, {"end": 3118.16, "start": 3117.76, "text": "doing"}, {"end": 3118.48, "start": 3118.16, "text": "theta"}, {"end": 3118.76, "start": 3118.48, "text": "n"}, {"end": 3119.16, "start": 3118.76, "text": "work"}, {"end": 3119.92, "start": 3119.16, "text": "because"}, {"end": 3119.96, "start": 3119.92, "text": "you'll"}], "text": " All right. So overall, what you have is you have something like t of nm equals t of n m over 2 plus theta n. Why is that? Well, n is the number of rows. m is the number of columns. In one case, you will be breaking things down into half the number of columns, which is m over 2. And in order to find the global maximum, you'll be doing theta n work because you'll"}, {"chunks": [{"end": 3120.24, "start": 3120.0, "text": "scanning"}, {"end": 3120.32, "start": 3120.24, "text": "the"}, {"end": 3120.6, "start": 3120.32, "text": "global"}, {"end": 3120.96, "start": 3120.6, "text": "maximum."}, {"end": 3121.4, "start": 3120.96, "text": "You"}, {"end": 3121.56, "start": 3121.4, "text": "just"}, {"end": 3121.76, "start": 3121.56, "text": "have"}, {"end": 3122.0, "start": 3121.76, "text": "to"}, {"end": 3122.4, "start": 3122.0, "text": "scan"}, {"end": 3123.24, "start": 3122.4, "text": "it."}, {"end": 3123.64, "start": 3123.24, "text": "That's"}, {"end": 3124.36, "start": 3123.64, "text": "what"}, {"end": 3124.68, "start": 3124.36, "text": "it's"}, {"end": 3125.16, "start": 3124.68, "text": "going"}, {"end": 3125.6, "start": 3125.16, "text": "to"}, {"end": 3126.56, "start": 3125.6, "text": "take."}, {"end": 3127.28, "start": 3126.56, "text": "And"}, {"end": 3127.6, "start": 3127.28, "text": "so"}, {"end": 3128.12, "start": 3127.6, "text": "if"}, {"end": 3128.32, "start": 3128.12, "text": "you"}, {"end": 3128.76, "start": 3128.32, "text": "do"}, {"end": 3129.48, "start": 3128.76, "text": "that"}, {"end": 3130.32, "start": 3129.48, "text": "and"}, {"end": 3130.52, "start": 3130.32, "text": "you"}, {"end": 3131.12, "start": 3130.52, "text": "go"}, {"end": 3131.48, "start": 3131.12, "text": "run"}, {"end": 3131.84, "start": 3131.48, "text": "it"}, {"end": 3132.24, "start": 3131.84, "text": "through,"}, {"end": 3132.92, "start": 3132.24, "text": "and"}, {"end": 3133.24, "start": 3132.92, "text": "you"}, {"end": 3133.84, "start": 3133.24, "text": "know"}, {"end": 3134.04, "start": 3133.84, "text": "that"}, {"end": 3134.12, "start": 3134.04, "text": "t"}, {"end": 3134.36, "start": 3134.12, "text": "of"}, {"end": 3134.48, "start": 3134.36, "text": "n1"}, {"end": 3134.68, "start": 3134.48, "text": "is"}, {"end": 3134.72, "start": 3134.68, "text": "theta"}, {"end": 3135.68, "start": 3134.72, "text": "n,"}, {"end": 3136.0, "start": 3135.68, "text": "which"}, {"end": 3136.12, "start": 3136.0, "text": "is"}, {"end": 3136.32, "start": 3136.12, "text": "this"}, {"end": 3136.56, "start": 3136.32, "text": "last"}, {"end": 3136.92, "start": 3136.56, "text": "part"}, {"end": 3137.68, "start": 3136.92, "text": "over"}, {"end": 3139.08, "start": 3137.68, "text": "here."}, {"end": 3139.56, "start": 3139.08, "text": "That's"}, {"end": 3139.6, "start": 3139.56, "text": "your"}, {"end": 3139.84, "start": 3139.6, "text": "base"}, {"end": 3140.88, "start": 3139.84, "text": "case."}, {"end": 3141.28, "start": 3140.88, "text": "You"}, {"end": 3141.6, "start": 3141.28, "text": "get"}, {"end": 3142.08, "start": 3141.6, "text": "t"}, {"end": 3142.2, "start": 3142.08, "text": "of"}, {"end": 3143.32, "start": 3142.2, "text": "nm"}, {"end": 3143.76, "start": 3143.32, "text": "is"}, {"end": 3144.36, "start": 3143.76, "text": "theta"}, {"end": 3144.64, "start": 3144.36, "text": "of"}, {"end": 3145.36, "start": 3144.64, "text": "n"}, {"end": 3145.84, "start": 3145.36, "text": "added"}, {"end": 3146.68, "start": 3145.84, "text": "to"}, {"end": 3146.8, "start": 3146.68, "text": "theta"}, {"end": 3146.88, "start": 3146.8, "text": "of"}, {"end": 3147.92, "start": 3146.88, "text": "n"}, {"end": 3148.6, "start": 3147.92, "text": "log"}, {"end": 3149.08, "start": 3148.6, "text": "of"}, {"end": 3149.4, "start": 3149.08, "text": "m"}, {"end": 3149.96, "start": 3149.4, "text": "times."}], "text": " scanning the global maximum. You just have to scan it. That's what it's going to take. And so if you do that and you go run it through, and you know that t of n1 is theta n, which is this last part over here. That's your base case. You get t of nm is theta of n added to theta of n log of m times."}, {"chunks": [{"end": 3150.08, "start": 3150.0, "text": "log"}, {"end": 3152.8, "start": 3150.08, "text": "2"}, {"end": 3153.44, "start": 3152.8, "text": "of"}, {"end": 3153.68, "start": 3153.44, "text": "m"}, {"end": 3154.8, "start": 3153.68, "text": "times,"}, {"end": 3155.0, "start": 3154.8, "text": "which"}, {"end": 3155.88, "start": 3155.0, "text": "is"}, {"end": 3157.08, "start": 3155.88, "text": "theta"}, {"end": 3157.28, "start": 3157.08, "text": "of"}, {"end": 3158.24, "start": 3157.28, "text": "n"}, {"end": 3158.36, "start": 3158.24, "text": "log"}, {"end": 3160.76, "start": 3158.36, "text": "2"}, {"end": 3160.96, "start": 3160.76, "text": "of"}, {"end": 3161.04, "start": 3160.96, "text": "m."}, {"end": 3162.2, "start": 3161.04, "text": "All"}, {"end": 3163.6, "start": 3162.2, "text": "right?"}, {"end": 3164.68, "start": 3163.6, "text": "So"}, {"end": 3164.92, "start": 3164.68, "text": "you're"}, {"end": 3165.48, "start": 3164.92, "text": "not"}, {"end": 3165.52, "start": 3165.48, "text": "done"}, {"end": 3165.64, "start": 3165.52, "text": "with"}, {"end": 3165.84, "start": 3165.64, "text": "peak"}, {"end": 3166.08, "start": 3165.84, "text": "finding."}, {"end": 3166.16, "start": 3166.08, "text": "What"}, {"end": 3166.76, "start": 3166.16, "text": "you'll"}, {"end": 3166.84, "start": 3166.76, "text": "see"}, {"end": 3167.04, "start": 3166.84, "text": "is"}, {"end": 3167.72, "start": 3167.04, "text": "that"}, {"end": 3168.16, "start": 3167.72, "text": "four"}, {"end": 3168.68, "start": 3168.16, "text": "algorithms"}, {"end": 3169.2, "start": 3168.68, "text": "coded"}, {"end": 3169.88, "start": 3169.2, "text": "in"}, {"end": 3170.4, "start": 3169.88, "text": "Python."}, {"end": 3170.92, "start": 3170.4, "text": "I'm"}, {"end": 3171.16, "start": 3170.92, "text": "not"}, {"end": 3171.56, "start": 3171.16, "text": "going"}, {"end": 3171.56, "start": 3171.56, "text": "to"}, {"end": 3171.6, "start": 3171.56, "text": "give"}, {"end": 3171.8, "start": 3171.6, "text": "away"}, {"end": 3173.4, "start": 3171.8, "text": "what"}, {"end": 3173.56, "start": 3173.4, "text": "those"}, {"end": 3174.68, "start": 3173.56, "text": "algorithms"}, {"end": 3174.88, "start": 3174.68, "text": "are,"}, {"end": 3174.92, "start": 3174.88, "text": "but"}, {"end": 3174.96, "start": 3174.92, "text": "you'll"}, {"end": 3175.32, "start": 3174.96, "text": "have"}, {"end": 3175.6, "start": 3175.32, "text": "to"}, {"end": 3176.28, "start": 3175.6, "text": "recognize"}, {"end": 3176.28, "start": 3176.28, "text": "them."}, {"end": 3176.28, "start": 3176.28, "text": "You"}, {"end": 3176.84, "start": 3176.28, "text": "will"}, {"end": 3177.52, "start": 3176.84, "text": "have"}, {"end": 3178.4, "start": 3177.52, "text": "seen"}, {"end": 3178.84, "start": 3178.4, "text": "versions"}, {"end": 3179.04, "start": 3178.84, "text": "of"}, {"end": 3179.08, "start": 3179.04, "text": "those"}, {"end": 3179.96, "start": 3179.08, "text": "algorithms"}], "text": " log 2 of m times, which is theta of n log 2 of m. All right? So you're not done with peak finding. What you'll see is that four algorithms coded in Python. I'm not going to give away what those algorithms are, but you'll have to recognize them. You will have seen versions of those algorithms"}, {"chunks": [{"end": 3180.48, "start": 3180.0, "text": "already"}, {"end": 3180.56, "start": 3180.48, "text": "in"}, {"end": 3181.88, "start": 3180.56, "text": "lecture."}, {"end": 3182.32, "start": 3181.88, "text": "And"}, {"end": 3182.6, "start": 3182.32, "text": "your"}, {"end": 3182.72, "start": 3182.6, "text": "job"}, {"end": 3183.24, "start": 3182.72, "text": "is"}, {"end": 3183.4, "start": 3183.24, "text": "going"}, {"end": 3183.44, "start": 3183.4, "text": "to"}, {"end": 3183.8, "start": 3183.44, "text": "be"}, {"end": 3184.72, "start": 3183.8, "text": "to"}, {"end": 3184.96, "start": 3184.72, "text": "analyze"}, {"end": 3185.04, "start": 3184.96, "text": "the"}, {"end": 3185.92, "start": 3185.04, "text": "algorithms,"}, {"end": 3186.28, "start": 3185.92, "text": "as"}, {"end": 3186.4, "start": 3186.28, "text": "I"}, {"end": 3186.4, "start": 3186.4, "text": "said"}, {"end": 3187.4, "start": 3186.4, "text": "before,"}, {"end": 3187.68, "start": 3187.4, "text": "prove"}, {"end": 3187.92, "start": 3187.68, "text": "that"}, {"end": 3188.04, "start": 3187.92, "text": "one"}, {"end": 3188.44, "start": 3188.04, "text": "of"}, {"end": 3188.68, "start": 3188.44, "text": "them"}, {"end": 3188.92, "start": 3188.68, "text": "is"}, {"end": 3189.6, "start": 3188.92, "text": "correct,"}, {"end": 3189.72, "start": 3189.6, "text": "and"}, {"end": 3189.92, "start": 3189.72, "text": "find"}, {"end": 3190.68, "start": 3189.92, "text": "counterexamples"}, {"end": 3190.76, "start": 3190.68, "text": "for"}, {"end": 3190.84, "start": 3190.76, "text": "the"}, {"end": 3191.28, "start": 3190.84, "text": "ones"}, {"end": 3191.6, "start": 3191.28, "text": "that"}, {"end": 3192.0, "start": 3191.6, "text": "aren't"}, {"end": 3192.56, "start": 3192.0, "text": "correct."}, {"end": 3192.76, "start": 3192.56, "text": "The"}, {"end": 3193.24, "start": 3192.76, "text": "course"}, {"end": 3193.52, "start": 3193.24, "text": "staff"}, {"end": 3193.6, "start": 3193.52, "text": "will"}, {"end": 3193.84, "start": 3193.6, "text": "stick"}, {"end": 3194.08, "start": 3193.84, "text": "around"}, {"end": 3194.6, "start": 3194.08, "text": "here"}, {"end": 3194.96, "start": 3194.6, "text": "to"}, {"end": 3195.24, "start": 3194.96, "text": "answer"}, {"end": 3195.72, "start": 3195.24, "text": "questions,"}, {"end": 3196.2, "start": 3195.72, "text": "logistical"}, {"end": 3197.0, "start": 3196.2, "text": "questions,"}, {"end": 3197.24, "start": 3197.0, "text": "or"}, {"end": 3197.64, "start": 3197.24, "text": "questions"}, {"end": 3197.8, "start": 3197.64, "text": "about"}, {"end": 3198.12, "start": 3197.8, "text": "lecture."}, {"end": 3198.24, "start": 3198.12, "text": "And"}, {"end": 3198.52, "start": 3198.24, "text": "I"}, {"end": 3198.64, "start": 3198.52, "text": "owe"}, {"end": 3198.84, "start": 3198.64, "text": "that"}, {"end": 3199.68, "start": 3198.84, "text": "gentleman"}, {"end": 3200.0, "start": 3199.68, "text": "a"}, {"end": 3200.96, "start": 3200.0, "text": "cushion."}], "text": " already in lecture. And your job is going to be to analyze the algorithms, as I said before, prove that one of them is correct, and find counterexamples for the ones that aren't correct. The course staff will stick around here to answer questions, logistical questions, or questions about lecture. And I owe that gentleman a cushion."}]}}