You need to enable JavaScript to run this app.
Home
A2OJ
Leaderboard
Roadmap
Code Editor
About
Home
A2OJ
Leaderboard
Roadmap
Code Editor
About
Roadmap
Learning path to get started in your CP journey.
Basics of Programming
1. C++ Basic
2. I/O , Conditional Statements
3. Loops, Pointers
4. Array, String
5. Function
Time and Space Complexity
1. Time Complexity
2. Space Complexity
3. Asymptotic Notation
STL
1. Vector and Pair
2. Iterator
3. Map and Set
4. Stack, Queue, Dequeue and Priority-Queue
5. STL algorithms
6. Sorting and Comparator Function
Array's Algorithm
1. Kadane's Algorithm
2. Window Sliding
3. Dutch National Flag Algorithm
4. Searching and Sorting
5. Prefix and Suffix sum
6. Two Pointer
7. 2D Array
String's Algorithm
1. KMP Algorithm
2. Rabin Karp Algorithm
3. Z-Algorithm
Greedy Algorithm
1. Activity Selection Problems
2. Egyptian Fraction
3. Job Sequencing
4. Minimum Swaps for Bracket Balancing
Binary Search
1. Binary Search I
2. Binary Search II
3. Binary Search III
4. Ternary Search
Number Theory
1. Euclid's GCD algorithm and Extended Euclid algorithm
2. Basic Modular Arithmetic
3. Modular Exponentiation
4. Modular Inverse
5. Prime Factorization of a number
6. Sieve of Eratosthenes
7. Segmented Sieve
8. Euler Totient Function
9. Fermat's Little Theorem
10. NCR mod p calculation
11. Lucas Theorem
12. Chinese Remainder Theorem
13. Mobius Function
Recursion and Backtracking
1. Recursion and Backtracking Basics
2. Subset Sum
3. Combination Sum
4. N queens Problem
5. Sudoku Solver
6. Rat in a Maze
Bit Manipulation
1. Number System
2. Bitwise Operators
3. Bit Masking
4. Binary Exponentiation
Dynamic Programming
1. Introduction
2. One Dimensional DP
3. Two Dimensional DP
2. Digit DP
3. DP on Trees
4. DP with Bitmask
5. SOS DP
6. Beginner to Advanced
7. Non Trivial DP Tricks and Techniques
8. CF Blog
Graph
1. Graph Representation
2. DFS
3. BFS
4. Bipartite Graph
5. Topological Sort
6. Kruskal's Algorithm
7. Prims's Algorithm
8. Dijkstra 's Algorithm
9. Bellman Ford's Algorithm
10. Floyd Warshall's Algorithm
11. Bridge
12. Articulation Points
13. Strongly Connected Components (SCC)
14. Tarjan's Algorithm for SCC
Tree
1. Traversal Techniques
2. Binary Tree, BST, Balanced Binary Tree
3. Binary Lifting
4. Bridges, BridgeTree, Cutpoits, SCC, DFS Tree
5. Dynamic Programming on tree
6. 2K Decomposition of tree (and Lowest Common Ancestor)
7. Kruskal Reconstruction Tree (KRT) (IOI Werewolf trick)
8. Set Merging (with linear height merging)
9. O(N^2) Distribution DP
10. 'Re-rooting' tree DP (where you DP twice, once going down and once propagating from top)
11. Centroid Decomposition
12. Heavy-Light Decomposition
13. UFDS on tree (See: CEOI 2017 Streets)
Miscellaneous Topics
1. Trie
2. Segment Tree & Fenwick Tree
3. Game Thoery
4. Probability & Expectation
5. Matrix Exponention
6. Euler Tour
Useful Links
Codeforces
Codechef
LeetCode
Atcoder
GeeksForGeeks
OEIS
USACO Guide
CP-Algorithms
Topcoder
CSES