Competition Programming and Problem Solving

15-195 and 15-295 Spring 2023

In this course you will learn the techniques and skills needed to solve algorithmic programming contests problems such as those that appear on the ICPC, Codeforces, DMOJ, and AtCoder. Much of your time will be spent writing programs on your own to solve problems.

But the skills you will pick up from the course are far more valuable than just enabling you to win contests. Many of the algorithms and techniques are classic ones that every computer scientist should know. You will also learn to think about algorithms in a deeper way, because many of the problems require you have to devise a new algorithm, not just apply a classic one. You will also become highly fluent in a programming language of your choice. These skills will be of great value in your other classes, in your job interviews, and in your future work, not to mention the satisfaction you will get from solving these problems.

Basic Information
Weekly Problems
Rules and Academic Integrity
Grading
Logistics
Training Resources
Learning Material
Diversity, Equity and Inclusion

Basic Information

The regular weekly contests will take place Wednesdays beginning at 7pm in Posner Hall 153, and last five hours (you don't have to stay the whole time.) Occasional lectures may take place, and will be announced on Discord. Lectures will cover introductory content aimed at beginners to competitive programming. Although attendance to the lectures is optional, it is strongly encouraged for beginners. During the contests, the instructor and the TA will be available for help in the classroom, or via Discord.

For more information on how to join these groups, etc, see the Logistics section below.

Weekly Contests

Week #10 (March 29): Theme: Insaner Bird

Contest: Here
Solutions: For Editing

Week #9 (March 22): Theme: Geese

Contest: Here
Solutions: For Editing

Week #8 (March 15): Theme: Flying

Contest: Here
Solutions: For Editing

Week #7 (March 1): Theme?

Contest: Here
Solutions: (Is there a solutions document?)

Week #6 (February 22): Theme?

Contest: Here
Solutions: (Is there a solutions document?)

Week #5 (February 15): More DP

Contest: Here
Solutions: For Editing

Week #4 (February 8): Dynamic programming

This week, we will practice the use of dynamic programming (DP) as a technique to solve programming competition problems. DP is quite possibly the most frequently occuring algorithmic technique used in competitions, with every ICPC contest always featuring at least one, if not several problems that require it. Mastering this technique is key to becoming a strong competitive programmer. DP revolves around two key concepts, optimal substructure, which means that a problem can be solved by breaking it into smaller versions of itself (much in the same way as divide and conquer), and memoization of overlapping subproblems, which means to cache the solutions to the smaller problems in case they need to be solved multiple times. Of all topics in competitive programming, it probably requires the most practice in order to master, so get started!

Resources: 451 Notes 1  451 Notes 2
Lecture Video: Here
Practice Contest: Here
Contest Link: Here
Solutions: For Editing For Viewing

Week #3 (February 1): Binary Search

This week, we will solve problems that use the binary search technique. You might think of binary search as an algorithm for finding an element in a sorted list, but it is actually a much more general technique than that, and can be used to solve a wide range of problems. Essentially, binary search allows you to solve problems where you must minimize or maximize some quantity subject to some contraint, as long as that constraint is monotone. A constraint is monotone if it is false for all values of x up to some value, and then becomes true after that value. Binary search allows us to efficiently find this partition point, and hence solve the corresponding optimization problem. The practice problems this week should help you to learn to apply this powerfull technique.

Lecture:  Video   binary search code   ternary search code
Practice Problems: Here
Contest Link: Here
Solutions: For Editing For Viewing

Week #2 (January 25): Built-in Algorithms and Data Structures

This week there will be no overall theme, but there will be some problems that will benefit from knowing how to use common built-in data structures, such as pairs, ordered sets (binary search trees), maps (hash tables), and priority queues. Check out the lecture linked below by Daniel Anderson which talks about how to use these features of C++.

Lecture Video (Daniel Anderson): Here
Solutions: For Editing For Viewing

Week #1 (January 18): Introduction

This week has no particular algorithmic theme. Instead, we will go over the basics of competitive programming and do our first contest on DMOJ. Please make sure you have a DMOJ account ready to go and understand how to upload your solutions to the problems. We have created a practice contest to do just that. You should do some practice problems to get the hang of writing and submitting solutions to the DMOJ system.

See the logistics section below to set up your DMOJ account, and join "Carnegie Mellon University".

If you don't know how to read from standard input and write to standard output, here's a tutorial showing how to do it.

Practice Problems: Link
Contest Link: Here
Solutions: For editing  For viewing

Rules and Academic Integrity

You can make use of generic on-line resources while solving problems. These include things like language documentation, API documentation, algorithm descriptions, terminology, etc. You are allowed to use any code you have written, at any time in the past, for any purpose. However, you should not search for or make use of code written by others to solve the specific assigned problem. You're allowed to copy somewhat standard pieces of code (e.g. a primality test) that you find on-line or in a book.

So to summarize, each student should write his or her own code. If you're stuck on a problem, you are welcome to discuss it with another student in the class, or the course staff. But you cannot copy another student's code.

The violations described above are regarded as an academic integrity violation, and -- depending on the severity -- will result in penalties and/or be reported to the appropriate university authorities.

Grading

This course is 5 units. Each week you will be given several problems to try to solve during class. You will be allowed (for half credit) to solve these problems during the week after the contest ends. You can also get credit for solving problems during rated contests on Codeforces. (This site run rated contests approximately every two weeks.)

To be more specific, you can earn points from the following sources:

The differences between 15-195 and 15-295 are: Students enrolled in 15-295 will not get credit for problems A and B of the weekly contests, but 15-195 students can. A student can take 15-195 only once, but 15-295 can be taken repeatedly.

Here is how your grade is determined:

score ≥ 25: A
score ≥ 15: B
score ≥ 10: C
score ≥   5: D

Logistics

Training Resources

First of all if you need help reading from standard input, or writing to standard output, see this link.

There are many online resources available for you to train with if you intend to become a serious competitive programmer. You can find thousands of practice problems for you practice and improve your skills. Some good places to find practice problems include:

Learning Material

If you are a beginner looking for resources to learn the various topics that appear in typical contests, some good sources are:

Diversity, Equity, and Inclusion

We must treat every individual with respect. We are diverse in many ways, and this diversity is fundamental to building and maintaining an equitable and inclusive campus community. Diversity can refer to multiple ways that we identify ourselves, including but not limited to race, color, national origin, language, sex, disability, age, sexual orientation, gender identity, religion, creed, ancestry, belief, veteran status, or genetic information. Each of these diverse identities, along with many others not mentioned here, shape the perspectives our students, faculty, and staff bring to our campus. We, at CMU, will work to promote diversity, equity and inclusion not only because diversity fuels excellence and innovation, but because we want to pursue justice. We acknowledge our imperfections while we also fully commit to the work, inside and outside of our classrooms, of building and sustaining a campus community that increasingly embraces these core values.

Each of us is responsible for creating a safer, more inclusive environment.

Unfortunately, incidents of bias or discrimination do occur, whether intentional or unintentional. They contribute to creating an unwelcoming environment for individuals and groups at the university. Therefore, the university encourages anyone who experiences or observes unfair or hostile treatment on the basis of identity to speak out for justice and support, within the moment of the incident or after the incident has passed. Anyone can share these experiences using the following resources:

All reports will be documented and deliberated to determine if there should be any following actions. Regardless of incident type, the university will use all shared experiences to transform our campus climate to be more equitable and just.


Danny Sleator
Last modified: Thu Mar 30 13:19:27 2023