https://tanmayhinge.github.io/competitive-programming-workshop
I conducted this workshop titled "Getting Started with Competitive Programming" on 09 April 2022 while I was in my final year of computer science engineering at Pillai College of Engineering. It was conducted in association with CSI-PCE.
DataStructures and Algorithms were covered by Rahul Maurya and Aditya Nair respectively.
This document serves as a guide for anyone who wishes to get started with competitive programming as well as takeaway notes for the workshop participants.
- Introduction to Competitive Programming
- Why C++?
- Basic C++
- How to approach problems in competitive programming + Templates
- Some basic datastructures using STL
- Some basic algorithms using STL
- Activity
Competitive Programming is a sport where you make use of logic, math, problem solving skills and compete with other users to solve problems using code, usually by writing an algorithm to solve the problem.
Any programming language can be used for competitive programming but people generally use C++, Python and Java. C++ is the most used as well as preferred language by competitive programmers.
In these notes and workshop, I am using C++.
In the workshop we used the Codechef online IDE.
If you need to set up a local environment you can refer this video ---> YouTube Link
There are various platforms that conduct competitive programming contests periodically:
- CodeChef
- CodeForces
- LeetCode
- AtCoder
- Clist.by (Competitive Programming Calendar)
- StopStalk (Your all in one profile for competitive programming)
"C++ is fast" isnt enough justification anymore to choose C++ as your choice of language because many competitive platforms have adjusted their time limits as per the language being used.
On the other hand, it is wise to use C++ because of its rich "Standard Template Library" also abbrevated as STL.
STL provides you with a strong set of tools that make competitive programming less of a hassle.
Array is just a simple example that shows how powerful C++ STL is....
We will see a few more as we progress ahead.....
main function, header files, variables, datatypes, input, output,
Explained in the workshop using a follow-along way of teaching for each concept where the participants wrote code for all the basics.
To refer all those concepts again you may use this YouTube Video from freecodecamp. Checkout the timestamps for individual explainations.
- How to read the problem statements
- Testing your code before submitting
- Various Errors
- Test Cases
- Templates
Here I explained my way of approaching a competitive programming problem. Various users may develop their own way of solving as they progress.
My way of approaching a problem is as follows:
Example take this problem from CodeChef
Here I would directly skip to the Input and Output format part rather than reading the whole "story" behind the problem.
Then I would go through the explaination.
If at this point I have not understood the problem, I would then and only then read the first few lines where they give more context about the problem...
For starters, you may want to read those lines but as you progress you would start to ignore them by habit....
When you are done writing your code, You can put the "sample input" given in the problem to the "Custom Input" area of the platform and "Run" instead of submit to test the code.
- Compilation Error
- Runtime Error
- Time Limit Error
- Failed Test Cases
A test case consists of an input to the code and an expected output.
There are some hidden and some non-hidden test cases.
Usually competitive programmers do not code everything from scratch. We have some self defined macros, functions and variables that leaves us with only writing the logic during competitions. In most of the competitions, using a template is alright, however some may ban the use of those.
It is important to understand C++ deeply before you use a very complex template. For now, this template is this best to begin with...
template.cpp (Non Commented Version)
Commented version:
#include<bits/stdc++.h> // includes all the header files needed for competitive programming
using namespace std; // declares that all the code will be in standard namespace
int main(){
int t; // for no. of test cases
// take other static inputs here
cin>>t;
while(t--){
// main logic goes here
}
return 0;
}
A short contest was hosted on CodeChef.