mirror of
https://hub.njuu.cf/TheAlgorithms/C-Plus-Plus.git
synced 2023-10-11 13:05:55 +08:00
ea76786f12
* Implementated Grahamscan Algorithm for Convex Hull * Update graham_scan_algorithm.cpp * Update graham_scan_functions.h * Update graham_scan_algorithm.cpp * Update graham_scan_functions.h * Update graham_scan_algorithm.cpp * Update and rename graham_scan_functions.h to graham_scan_functions.hpp * Update geometry/graham_scan_algorithm.cpp Co-authored-by: David Leal <halfpacho@gmail.com> * Update geometry/graham_scan_algorithm.cpp Co-authored-by: David Leal <halfpacho@gmail.com> * Update geometry/graham_scan_functions.hpp Co-authored-by: David Leal <halfpacho@gmail.com> * Update geometry/graham_scan_functions.hpp Co-authored-by: David Leal <halfpacho@gmail.com> * updating DIRECTORY.md * clang-format and clang-tidy fixes fore89e4c8c
* clang-format and clang-tidy fixes for7df4778f
* Fix #1 * Update graham_scan_functions.hpp * Delete composite_simpson_rule.cpp * Delete inverse_fast_fourier_transform.cpp * Fix #2 * updating DIRECTORY.md * clang-format and clang-tidy fixes for69b6832b
* Fix #3 * clang-format and clang-tidy fixes for1c05ca7c
* Update graham_scan_functions.hpp * Fix #4 * clang-format and clang-tidy fixes for2957fd21
* Create composite_simpson_rule.cpp * updating DIRECTORY.md * Create inverse_fast_fourier_transform.cpp * updating DIRECTORY.md * clang-format and clang-tidy fixes for405d21a5
* clang-format and clang-tidy fixes for333ef5ca
* Update geometry/graham_scan_functions.hpp Co-authored-by: David Leal <halfpacho@gmail.com> * Update geometry/graham_scan_algorithm.cpp Co-authored-by: David Leal <halfpacho@gmail.com> * Update geometry/graham_scan_algorithm.cpp Co-authored-by: David Leal <halfpacho@gmail.com> * Update geometry/graham_scan_algorithm.cpp Co-authored-by: David Leal <halfpacho@gmail.com> * Update geometry/graham_scan_functions.hpp Co-authored-by: David Leal <halfpacho@gmail.com> * Update geometry/graham_scan_algorithm.cpp Co-authored-by: David Leal <halfpacho@gmail.com> * Update geometry/graham_scan_algorithm.cpp Co-authored-by: David Leal <halfpacho@gmail.com> * clang-format and clang-tidy fixes foree4cb635
* Update graham_scan_algorithm.cpp * Update graham_scan_functions.hpp * clang-format and clang-tidy fixes forf2f69234
* Update graham_scan_functions.hpp * Create partition_problem.cpp * Update partition_problem.cpp * Delete partition_problem.cpp Co-authored-by: David Leal <halfpacho@gmail.com> Co-authored-by: github-actions <${GITHUB_ACTOR}@users.noreply.github.com>
36 KiB
36 KiB
Backtracking
- Graph Coloring
- Knight Tour
- Magic Sequence
- Minimax
- N Queens
- N Queens All Solution Optimised
- Nqueen Print All Solutions
- Rat Maze
- Subarray Sum
- Subset Sum
- Sudoku Solve
- Wildcard Matching
Bit Manipulation
Ciphers
- A1Z26 Cipher
- Atbash Cipher
- Base64 Encoding
- Caesar Cipher
- Elliptic Curve Key Exchange
- Hill Cipher
- Morse Code
- Uint128 T
- Uint256 T
- Vigenere Cipher
- Xor Cipher
Cpu Scheduling Algorithms
Data Structures
- Avltree
- Binary Search Tree
- Binary Search Tree2
- Binaryheap
- Circular Queue Using Linked List
- Cll
- Disjoint Set
- Doubly Linked List
- Dsu Path Compression
- Dsu Union Rank
- Linked List
- Linkedlist Implentation Usingarray
- List Array
- Morrisinorder
- Queue
- Queue Using Array
- Queue Using Array2
- Queue Using Linked List
- Queue Using Linkedlist
- Queue Using Two Stacks
- Rb Tree
- Reverse A Linked List
- Skip List
- Sparse Table
- Stack
- Stack Using Array
- Stack Using Linked List
- Stack Using Queue
- Test Queue
- Test Stack
- Test Stack Students
- Tree
- Tree 234
- Trie Modern
- Trie Tree
- Trie Using Hashmap
Divide And Conquer
Dynamic Programming
- 0 1 Knapsack
- Abbreviation
- Armstrong Number
- Bellman Ford
- Catalan Numbers
- Coin Change
- Coin Change Topdown
- Cut Rod
- Edit Distance
- Egg Dropping Puzzle
- Fibonacci Bottom Up
- Floyd Warshall
- House Robber
- Kadane
- Kadane2
- Longest Common String
- Longest Common Subsequence
- Longest Increasing Subsequence
- Longest Increasing Subsequence (Nlogn)
- Longest Palindromic Subsequence
- Matrix Chain Multiplication
- Minimum Edit Distance
- Palindrome Partitioning
- Partition Problem
- Searching Of Element In Dynamic Array
- Shortest Common Supersequence
- Tree Height
- Word Break
Geometry
Graph
- Bidirectional Dijkstra
- Breadth First Search
- Bridge Finding With Tarjan Algorithm
- Connected Components
- Connected Components With Dsu
- Cycle Check Directed Graph
- Depth First Search
- Depth First Search With Stack
- Dijkstra
- Hamiltons Cycle
- Hopcroft Karp
- Is Graph Bipartite
- Is Graph Bipartite2
- Kosaraju
- Kruskal
- Lowest Common Ancestor
- Max Flow With Ford Fulkerson And Edmond Karp Algo
- Prim
- Topological Sort
- Topological Sort By Kahns Algo
- Travelling Salesman Problem
Graphics
Greedy Algorithms
Hashing
Linear Algebra
Machine Learning
- A Star Search
- Adaline Learning
- Kohonen Som Topology
- Kohonen Som Trace
- Neural Network
- Ordinary Least Squares Regressor
- Vector Ops
Math
- Area
- Armstrong Number
- Binary Exponent
- Binomial Calculate
- Check Amicable Pair
- Check Factorial
- Check Prime
- Complex Numbers
- Double Factorial
- Eulers Totient Function
- Extended Euclid Algorithm
- Factorial
- Fast Power
- Fibonacci
- Fibonacci Fast
- Fibonacci Large
- Fibonacci Matrix Exponentiation
- Fibonacci Sum
- Finding Number Of Digits In A Number
- Gcd Iterative Euclidean
- Gcd Of N Numbers
- Gcd Recursive Euclidean
- Integral Approximation
- Integral Approximation2
- Inv Sqrt
- Large Factorial
- Large Number
- Largest Power
- Lcm Sum
- Least Common Multiple
- Linear Recurrence Matrix
- Magic Number
- Miller Rabin
- Modular Division
- Modular Exponentiation
- Modular Inverse Fermat Little Theorem
- N Bonacci
- N Choose R
- Ncr Modulo P
- Number Of Positive Divisors
- Power For Huge Numbers
- Power Of Two
- Prime Factorization
- Prime Numbers
- Primes Up To Billion
- Realtime Stats
- Sieve Of Eratosthenes
- Sqrt Double
- String Fibonacci
- Sum Of Binomial Coefficient
- Sum Of Digits
- Vector Cross Product
- Volume
Numerical Methods
- Babylonian Method
- Bisection Method
- Brent Method Extrema
- Composite Simpson Rule
- Durand Kerner Roots
- False Position
- Fast Fourier Transform
- Gaussian Elimination
- Golden Search Extrema
- Inverse Fast Fourier Transform
- Lu Decompose
- Lu Decomposition
- Midpoint Integral Method
- Newton Raphson Method
- Ode Forward Euler
- Ode Midpoint Euler
- Ode Semi Implicit Euler
- Qr Decompose
- Qr Decomposition
- Qr Eigen Values
- Rungekutta
- Successive Approximation
Operations On Datastructures
- Array Left Rotation
- Array Right Rotation
- Circular Linked List
- Circular Queue Using Array
- Get Size Of Linked List
- Inorder Successor Of Bst
- Intersection Of Two Arrays
- Reverse A Linked List Using Recusion
- Reverse Binary Tree
- Selectionsortlinkedlist
- Trie Multiple Search
- Union Of Two Arrays
Others
- Buzz Number
- Decimal To Binary
- Decimal To Hexadecimal
- Decimal To Roman Numeral
- Easter
- Fast Integer Input
- Happy Number
- Iterative Tree Traversals
- Kadanes3
- Lru Cache
- Matrix Exponentiation
- Palindrome Of Number
- Paranthesis Matching
- Pascal Triangle
- Postfix Evaluation
- Primality Test
- Smallest Circle
- Sparse Matrix
- Spiral Print
- Stairs Pattern
- Tower Of Hanoi
- Vector Important Functions
Probability
Range Queries
- Fenwick Tree
- Heavy Light Decomposition
- Mo
- Persistent Seg Tree Lazy Prop
- Prefix Sum Array
- Segtree
- Sparse Table
Search
- Binary Search
- Exponential Search
- Fibonacci Search
- Floyd Cycle Detection Algo
- Hash Search
- Interpolation Search
- Interpolation Search2
- Jump Search
- Linear Search
- Median Search
- Saddleback Search
- Sublist Search
- Ternary Search
- Text Search
Sorting
- Bead Sort
- Bitonic Sort
- Bogo Sort
- Bubble Sort
- Bucket Sort
- Cocktail Selection Sort
- Comb Sort
- Count Inversions
- Counting Sort
- Counting Sort String
- Cycle Sort
- Dnf Sort
- Gnome Sort
- Heap Sort
- Insertion Sort
- Library Sort
- Merge Insertion Sort
- Merge Sort
- Non Recursive Merge Sort
- Numeric String Sort
- Odd Even Sort
- Pancake Sort
- Pigeonhole Sort
- Quick Sort
- Quick Sort 3
- Radix Sort
- Radix Sort2
- Random Pivot Quick Sort
- Recursive Bubble Sort
- Selection Sort Iterative
- Selection Sort Recursive
- Shell Sort
- Shell Sort2
- Slow Sort
- Strand Sort
- Swap Sort
- Tim Sort
- Wave Sort
- Wiggle Sort