Top 10 Algorithms and Data Structures for Competitive Programming Last Updated : 15 Dec, 2022 Improve Improve Like Article Like Save Share Report In this post, we will discuss Important top 10 algorithms and data structures for competitive coding. Topics : Graph algorithms Dynamic programming Searching and Sorting: Number theory and Other Mathematical Geometrical and Network Flow Algorithms Data Structures The links below cover most important algorithms and data structure topics: Graph Algorithms Breadth First Search (BFS) Depth First Search (DFS) Shortest Path from source to all vertices **Dijkstra** Shortest Path from every vertex to every other vertex **Floyd Warshall** Minimum Spanning tree **Prim** Minimum Spanning tree **Kruskal** Topological Sort Johnson’s algorithm Articulation Points (or Cut Vertices) in a Graph Bridges in a graph All Graph Algorithms Dynamic Programming Longest Common Subsequence Longest Increasing Subsequence Edit Distance Minimum Partition Ways to Cover a Distance Longest Path In Matrix Subset Sum Problem Optimal Strategy for a Game 0-1 Knapsack Problem Assembly Line Scheduling All DP Algorithms Searching And Sorting Binary Search Quick Sort Merge Sort Order Statistics KMP algorithm Rabin karp Z’s algorithm Aho Corasick String Matching Counting Sort Manacher’s algorithm: Part 1, Part 2 and Part 3 All Articles on Searching, Sorting and Pattern Searching. Number theory and Other Mathematical Prime Numbers and Prime Factorization Primality Test | Set 1 (Introduction and School Method) Primality Test | Set 2 (Fermat Method) Primality Test | Set 3 (Miller–Rabin) Sieve of Eratosthenes Segmented Sieve Wilson’s Theorem Prime Factorization Pollard’s rho algorithm Modulo Arithmetic Algorithms Basic and Extended Euclidean algorithms Euler’s Totient Function Modular Exponentiation Modular Multiplicative Inverse Chinese remainder theorem Introduction Chinese remainder theorem and Modulo Inverse Implementation nCr%m and this. Miscellaneous: Counting Inversions Counting Inversions using BIT logarithmic exponentiation Square root of an integer Heavy light Decomposition , this and this Matrix Rank Gaussian Elimination to Solve Linear Equations Hungarian algorithm Link cut Mo’s algorithm and this Factorial of a large number in C++ Factorial of a large number in Java+ Russian Peasant Multiplication Catalan Number All Articles on Mathematical Algorithms Geometrical and Network Flow Algorithms Convex Hull Graham Scan Line Intersection Interval Tree Matrix Exponentiation and this Maxflow Ford Furkerson Algo and Edmond Karp Implementation Min cut Stable Marriage Problem Hopcroft–Karp Algorithm for Maximum Matching Dinic’s algo and e-maxx All Articles on Geometric Algorithms Data Structures Binary Indexed Tree or Fenwick tree Segment Tree (RMQ, Range Sum and Lazy Propagation) K-D tree (See insert, minimum and delete) Union Find Disjoint Set (Cycle Detection and By Rank and Path Compression) Tries Suffix array (this, this and this) Sparse table Suffix automata Suffix automata II LCA and RMQ All Articles on Advanced Data Structures. How to Begin? Please see How to begin with Competitive Programming? How to Practice? Please see https://practice.geeksforgeeks.org/ What are top algorithms in Interview Questions? Top 10 algorithms in Interview Questions How to prepare for ACM – ICPC? How to prepare for ACM – ICPC? This is an initial draft. We will soon be adding more links and algorithms to this post. The biggest mistake programmers make is probably getting discouraged and not practicing enough. Or practicing only on problems they feel they’re good at. – Derek Kisman, aka SnapDragon Related Courses Competitive Programming – Live Course Taking the first step is always hard, isn’t it? But we say no, why? Because we’ve brought a course that will help you to top the charts of leading coding competitions and interviews. Great right? You can start your journey of being a Competitive Programmer now, but before you start know the basics of Data structures and algorithms and programming foundations. Enrol Today, we’ll see you inside the course. Like Article Suggest improvement Previous What Are The Best Resources For Competitive Programming? Next Can ChatGPT be used to solve Competitive Coding Problems? Share your thoughts in the comments Add Your Comment Please Login to comment...