- Teacher: Rossano Venturini
- CFU: 6
- Period: First semester
- Language: English
- Classroom: here
- Lectures schedule: Monday 14-16 and Wednesday 11-13 (Google Meet).
- Question time: After lectures or by appointment
- Google group to discuss solutions
The goal of the course is to improve programming and problem solving skills of the students by facing them with difficult problems and by presenting the techniques that help their reasoning in the implementation of correct and efficient solutions. The importance of these skills has been recognized by the most important software companies worldwide, which evaluate candidates in their job interviews mostly by the ability in addressing such difficult problems (e.g., see here).
A natural goal is to involve the students in the intellectual pleasure of programming and problem solving, also preparing them for the most important international online contests, such as Topcoder, Codeforces, HackerRank, CodeChef, Facebook Hacker Cup, Google Code Jam and so on, for internships in most important companies and their interviews. A desirable side-effect of the course could be to organize and prepare teams of students for online contests.
The course will provide the opportunity of
- facing with challenging algorithmic problems;
- improving problem solving and programming skills;
- getting in touch with some big companies for internships, scholarships, or thesis proposals.
The exam consists of two parts: Homeworks 50% - Written/oral test 50%.
Extra points for
- active participation to our Google group
- serious participation to online contests, e.g., CodeForces, TopCoder, Hacker Rank, Google Code Jam, ...
- successful interview with a big company
For full marks in the "Homeworks" part of the exam you must solve all the problems. I'll check your solutions by reading the code and their descriptions and by submitting them to the problems' sites. I should be able to submit any solution without any change. A solution that doesn't pass the tests (for any reason) will be considered wrong!
Please create a github repository to collect all your solutions and their descriptions. The repository can be either private or public. In both cases I should be able to access it. Please send me a link to your repository and keep the repository updated. I should be able to monitor your progresses.
The quality of your code will be evaluated. As your style will improve a lot with practice, I'll evaluate only the quality of the last submitted solutions.
Type | Date | Room | Text |
---|---|---|---|
Written/Lab | 23/01/2018 9:30 | H | Text, TestSet, and Solution |
Written/Lab | 14/02/2018 9:30 | M | Text, TestSet, and Quadratic solution |
Written/Lab | 12/06/2018 14:00 | H | Text, TestSet, and Solution |
Written/Lab | 06/07/2018 9:30 | I | Text and TestSet |
Written/Lab | 14/01/2019 14:00 | H | Text and TestSet |
- Read carefully the description of the problem.
- Make sure you understand the problem by checking the examples.
- Design a first trivial solution.
- Think about a more efficient solution. The use of some running examples usually helps a lot in finding a better solution. If your are not able to find such solution, try to find some hints by discussing with other students, by asking questions on the group, by looking at the solution in our Web page, or by searching on internet. This is perfectly fine for the first problems and for most difficult ones. In any case, make sure you really understand the solution and the properties it is exploiting!
- Write a brief description of your solution in English. Provide an analysis of its time and space complexity.
- Implement your own solution in C++.
- Submit your implementation to the problem's site. Fix it until it passes all the tests.
- Always compare your solution and your implementation with existing ones.
If you wish to refresh your mind on basic Algorithms and Data Structures, I suggest you to look at the well-known book Introduction to Algorithms, 3rd Edition by Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, Clifford Stein.
I strongly suggest you to watch the following video lectures as soon as possible.
- Insertion Sort and Merge Sort
- Heaps and Heap Sort
- Counting Sort, Radix Sort, Lower Bounds for Sorting
- Binary Search Trees
- AVL trees
- Hashing with Chaining
- Introduction to Algorithms, 3rd Edition, Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, Clifford Stein, The MIT Press, 2009 (Amazon) [CCLR]
- Algorithms, 4th Edition, Robert Sedgewick, Kevin Wayne, Addison-Wesley Professional, 2011 (Amazon) [RS]
- Algorithms, Sanjoy Dasgupta, Christos Papadimitriou, Umesh Vazirani, McGraw-Hill, 2006. (Amazon) [DPZ]
- Programming Challenges: The Programming Contest Training Manual, Steven S. Skiena, Miguel A. Revilla, Springer, 2003 (Amazon) [SR]
- Competitive Programming 4: The New Lower Bound of Programming Contests, Steven Halim, Felix Halim, (here) [HH]
- Competitive Programmer's Handbook, Antti Laaksonen (here) [L]
- The C++ Programming Language, 4th Edition, Bjarne Stroustrup, Addison-Wesley Professional, 2013 (Amazon)
- A tour of C++, 2nd Edition, Bjarne Stroustrup, Addison-Wesley Professional, 2018 (Amazon)
- The C++ Standard Library: A Tutorial and Reference, 2nd Edition, Nicolai M. Josuttis, Addison-Wesley Professional, 2012 (Amazon)
- Erik D Demaine, Srini Devadas, Nancy Ann Lynch, "MIT Design and Analysis of Algorithms", MIT Algorithm course which includes video lectures
- Tim Roughgarden, "Algorithm specialization", Coursera
- Visualgo: visualising data structures and algorithms through animation
- Geeks for Geeks: Company interviews preparation
- Interviews common coding questions
- How to: Work at Google — Example Coding/Engineering Interview Video
- Google's Code Jam
- Topcoder
- Codeforces
- Geeks for Geeks
- CodeChef - Data Structures and Algorithms links
- Geeks for Geeks: Top 10 Algorithms and Data Structures for Competitive Programming
- List of resources for competitive programming
Date | Lecture | References | Problems |
---|---|---|---|
14/09/2020 | Introduction | Slides | Leaders in array (solution), Kadane's algorithm (solution), Missing number in array (solution), Trapping rain water (solution), and Sliding window maximum (solution) |
16/09/2020 | Solutions of Trapping rain water and Sliding window maximum | Rossano's notes* | Next larger element (solution), Towers (solution), and Finding Team Member (solution) |
23/09/2020 | Searching and Sorting: Binary Search, Merge Sort, QuickSort, Counting Sort, and Radix Sort | Rossano's notes*. [CCLR] Chapters 2.3, 7, and 8. Binary search. Exponential search. Interpolation search (optional) | Inversion count (solution) and The Monkey and the Oiled Bamboo |
28/09/2020 | Searching and Sorting: Binary Search, Merge Sort, QuickSort, Counting Sort, and Radix Sort | Two Types of Spells | |
30/09/2020 | Trees: representation, traversals, and Binary Search Tree | Rossano's notes*. [CCLR] Chapters 10.4 and 12. | Frogs and Mosquitoes |
05/10/2020 | Trees: representation, traversals, and Binary Search Tree | Rossano's notes*. Tree traversals. Euler Tour. Two pointers technique. | Maximum path sum (solution) and Longest k-Good Segment |
12/10/2020 | (Static) Prefix sum | Rossano's notes* | Ilya and Queries (solution), Number of ways (solution), and Little girl and maximum sum (solution) |
14/10/2020 | (Static) Prefix sum contd. | ||
19/10/2020 | Prefix sum: Binary Indexed Tree (aka BIT or Fenwick tree) | Rossano's notes*. BIT: description, tutorial, video, visualgo, and code. | Update the array (solution) |
21/10/2020 | Applications of BIT and Range update with BIT. | Rossano's notes*. Range updates on BIT. Tutorial. | Nested segments (solution) and Pashmak and Parmida's problem (solution) |
26/10/2020 | Segment Trees | Segment Tree: description, tutorial 1, tutorial 2, tutorial 3, video, visualgo, slides and code. | Solve Nested segments with Segment trees. |
02/11/2020 | Segment Trees: Lazy Propagation and Persistency | Segment Tree: description, tutorial 1, tutorial 2, tutorial 3, video, visualgo, slides and code. Lazy propagation: tutorial and video. | Circular RMQ |
04/11/2020 | Segment trees: Lazy Propagation and Persistency | ||
09/11/2020 | Exercises | Triplets (Text and TestSet) and Smaller Values (Text and TestSet) | |
11/11/2020 | Static RMQ with sparse table | RMQ and sparse table: tutorial 1, tutorial 2, paper, and code. Static RMQ in 2n + o(n) bits and constant time(optional). RMQ with BIT (optional) | |
16/11/2020 | Mo's algorithm on sequences and trees | Rossano's notes*. Mo's Algorithm: Sequences and Trees | Powerful array and Tree and queries |
18/11/2020 | Dynamic Programming: Fibonacci numbers, Rod cutting, and Longest common subsequence | Rossano's notes* (or pdf). [CCLR] Chapter 15. | Longest common subsequence |
23/11/2020 | Dynamic Programming: Minimum cost path, 0/1 Knapsack, Subset sum, and Coin change | Rossano's notes* (or pdf). | Minimum number of jumps |
30/11/2020 | Dynamic Programming: 0/1 Knapsack, fractional knapsack, and Subset sum. | Rossano's notes* (or pdf). 0/1 knapsack problem: tutorial | Subset sum and 0-1 knapsack |
02/12/2020 | Dynamic Programming: Longest increasing subsequence, Longest bitonic subsequence, Coin change, and Largest independent set on trees | Rossano's notes* (or pdf) | Longest increasing subsequence and Longest bitonic subsequence |
07/12/2020 | Dynamic Programming: Edit Distance, Longest palindromic subsequence, and Weighted job scheduling | Rossano's notes* (or pdf) | Edit distance, Vertex cover, and Longest palindromic subsequence |
09/12/2020 | Greedy algorithms: Activity Selection, Job sequencing, and Fractional knapsack problem | Rossano's notes*. Notes by Jeff Erickson. Job sequencing. Fractional Knapsack Problem | N meetings in one room, Magic numbers, Wilbur and array, and Alternative thinking |
Date | Lecture | References | Problems |
---|---|---|---|
02/12/2019 | Greedy Algorithms: Boxes and Hero | Rossano's notes*. Boxes and Hero. Huffman code: Section 7.4 in Notes by Jeff Erickson (optional). | Lexicographically maximum subsequence, Woodcutters, and Queue |
03/12/2019 | Graph algorithms: BFS, DFS, and Topological Sort | Rossano's notes*. [CCLR] Chapter 22 | X total shapes, IsBipartite, and Fox and names |
09/12/2019 | Graph algorithms: Strongly Connected Components and Single-Source Shortest Path | Rossano's notes*. [CCLR] Chapters 22 and 23 | Learning languages and Checkposts |
10/12/2019 | Graph algorithms: Minimum Spanning Tree (and Disjoint Sets data structures) | Rossano's notes*. [CCLR] Chapters 21 and 23. Kruskal: code, Disjoint Set: tutorial | Minimum spanning tree |
Date | Lecture | References | Problems |
---|---|---|---|
2017 | Simulation of the exam | Misha and forest | |
2018 | Centroid Decomposition of trees | Centroid Decomposition of trees: here, here, here, and here | |
2018 | String algorithms: Knuth-Morris-Pratt and Suffix array | Knuth-Morris-Pratt from [CLRS] Chapter 32.3. Knuth-Morris-Pratt. Optional: Rabin-Karp here from Algorithms on strings, trees, and sequences, D. Gusfield, Cambridge university press, here, and here. Suffix Array: Tutorial and implementation: here and here. Optional: Suffix Array in linear time here | Longest prefix suffix and Shift the string |
2018 | String algorithms: LCP array, trie and ternary search trie | Computing LCP array: Kasai et al.'s algorithm and here. Ternary search trie and a video. | |
2019 | Standard Template Library (STL) | Slides. Tutorial and STL algorithms | Megacity (solution), Find pair (solution), and Two heaps (solution) |
2019 | Standard Template Library (STL). Coding | Slides | |
2019 | Heavy-light Decomposition of trees. This lecture is not mandatory. | Heavy-light Decomposition of trees: here, here, and here. | QTREE, QTREE2, QTREE3, GOT, and Chef and the tree. |
* Notes marked with "Rossano's notes" are rough and non-exhaustive notes that I used while lecturing. Please use them just to have a list of the topics of each lecture and use other reported references to study these arguments.
- Aho-Corasick String Matching Algorithm
- Convex Hull
- Interval tree
- Merge Sort Tree
- Manacher's Algorithm: here and here
- Maximum flow
- Splay trees
- Sweep line algorithm