Awesome
The Algorithms - Go
Algorithms implemented in Go (for education)
The repository is a collection of open-source implementation of a variety of algorithms implemented in Go and licensed under MIT License.
Read our Contribution Guidelines before you contribute.
List of Algorithms
<!--- AUTOGENERATED ---> <!--- GODOCMD BEGIN --->Packages:
<details> <summary> <strong> ahocorasick </strong> </summary>Functions:
Advanced
: Advanced Function performing the Advanced Aho-Corasick algorithm. Finds and prints occurrences of each pattern.AhoCorasick
: AhoCorasick Function performing the Basic Aho-Corasick algorithm. Finds and prints occurrences of each pattern.ArrayUnion
: ArrayUnion Concats two arrays of int's into one.BoolArrayCapUp
: BoolArrayCapUp Dynamically increases an array size of bool's by 1.BuildAc
: Functions that builds Aho Corasick automaton.BuildExtendedAc
: BuildExtendedAc Functions that builds extended Aho Corasick automaton.ComputeAlphabet
: ComputeAlphabet Function that returns string of all the possible characters in given patterns.ConstructTrie
: ConstructTrie Function that constructs Trie as an automaton for a set of reversed & trimmed strings.Contains
: Contains Returns 'true' if array of int's 's' contains int 'e', 'false' otherwise.CreateNewState
: CreateNewState Automaton function for creating a new state 'state'.CreateTransition
: CreateTransition Creates a transition for function σ(state,letter) = end.GetParent
: GetParent Function that finds the first previous state of a state and returns it. Used for trie where there is only one parent.GetTransition
: GetTransition Returns ending state for transition σ(fromState,overChar), '-1' if there is none.GetWord
: GetWord Function that returns word found in text 't' at position range 'begin' to 'end'.IntArrayCapUp
: IntArrayCapUp Dynamically increases an array size of int's by 1.StateExists
: StateExists Checks if state 'state' exists. Returns 'true' if it does, 'false' otherwise.
Types
Result
: No description provided.
</details><details> <summary> <strong> armstrong </strong> </summary>
Functions:
IsArmstrong
: No description provided.
</details><details> <summary> <strong> binary </strong> </summary>
Package binary describes algorithms that use binary operations for different calculations.
Functions:
Abs
: Abs returns absolute value using binary operation Principle of operation: 1) Get the mask by right shift by the base 2) Base is the size of an integer variable in bits, for example, for int32 it will be 32, for int64 it will be 64 3) For negative numbers, above step sets mask as 1 1 1 1 1 1 1 1 and 0 0 0 0 0 0 0 0 for positive numbers. 4) Add the mask to the given number. 5) XOR of mask + n and mask gives the absolute value.BitCounter
: BitCounter - The function returns the number of set bits for an unsigned integer numberFastInverseSqrt
: FastInverseSqrt assumes that argument is always positive, and it does not deal with negative numbers. The "magic" number 0x5f3759df is hex for 1597463007 in decimals. The math.Float32bits is alias to *(*uint32)(unsafe.Pointer(&f)) and math.Float32frombits is to *(*float32)(unsafe.Pointer(&b)).IsPowerOfTwo
: IsPowerOfTwo This function uses the fact that powers of 2 are represented like 10...0 in binary, and numbers one less than the power of 2 are represented like 11...1. Therefore, using the and function: 10...0 & 01...1 00...0 -> 0 This is also true for 0, which is not a power of 2, for which we have to add and extra condition.IsPowerOfTwoLeftShift
: IsPowerOfTwoLeftShift This function takes advantage of the fact that left shifting a number by 1 is equivalent to multiplying by 2. For example, binary 00000001 when shifted by 3 becomes 00001000, which in decimal system is 8 or = 2 * 2 * 2LogBase2
: LogBase2 Finding the exponent of n = 2**x using bitwise operations (logarithm in base 2 of n) See moreMeanUsingAndXor
: MeanUsingAndXor This function finds arithmetic mean using "AND" and "XOR" operationsMeanUsingRightShift
: MeanUsingRightShift This function finds arithmetic mean using right shiftReverseBits
: ReverseBits This function initialized the result by 0 (all bits 0) and process the given number starting from its least significant bit. If the current bit is 1, set the corresponding most significant bit in the result and finally move on to the next bit in the input number. Repeat this till all its bits are processed.SequenceGrayCode
: SequenceGrayCode The function generates an "Gray code" sequence of length nSqrt
: No description provided.XorSearchMissingNumber
: XorSearchMissingNumber This function finds a missing number in a sequence
</details><details> <summary> <strong> cache </strong> </summary>
Functions:
NewLRU
: NewLRU represent initiate lru cache with capacityNewLFU
: NewLFU represent initiate lfu cache with capacityGet
: Get the value by key from LFU cachePut
: Put the key and value in LFU cache
Types
</details><details> <summary> <strong> caesar </strong> </summary>
Package caesar is the shift cipher ref: https://en.wikipedia.org/wiki/Caesar_cipher
Functions:
Decrypt
: Decrypt decrypts by left shift of "key" each character of "input"Encrypt
: Encrypt encrypts by right shift of "key" each character of "input"FuzzCaesar
: No description provided.
</details><details> <summary> <strong> catalan </strong> </summary>
Functions:
CatalanNumber
: CatalanNumber This function returns thenth
Catalan number
</details><details> <summary> <strong> checksum </strong> </summary>
Package checksum describes algorithms for finding various checksums
Functions:
CRC8
: CRC8 calculates CRC8 checksum of the given data.Luhn
: Luhn validates the provided data using the Luhn algorithm.
Types
CRCModel
: No description provided.
</details><details> <summary> <strong> coloring </strong> </summary>
Package coloring provides implementation of different graph coloring algorithms, e.g. coloring using BFS, using Backtracking, using greedy approach. Author(s): Shivam
Functions:
BipartiteCheck
: basically tries to color the graph in two colors if each edge connects 2 differently colored nodes the graph can be considered bipartite
Types
Graph
: No description provided.
</details><details> <summary> <strong> combination </strong> </summary>
Package combination ...
Functions:
Start
: Start ...
Types
Combinations
: No description provided.
</details><details> <summary> <strong> compression </strong> </summary>
Functions:
HuffDecode
: HuffDecode recursively decodes the binary code in, by traversing the Huffman compression tree pointed by root. current stores the current node of the traversing algorithm. out stores the current decoded string.HuffEncode
: HuffEncode encodes the string in by applying the mapping defined by codes.HuffEncoding
: HuffEncoding recursively traverses the Huffman tree pointed by node to obtain the map codes, that associates a rune with a slice of booleans. Each code is prefixed by prefix and left and right children are labelled with the booleans false and true, respectively.HuffTree
: HuffTree returns the root Node of the Huffman tree by compressing listfreq. The compression produces the most optimal code lengths, provided listfreq is ordered, i.e.: listfreq[i] <= listfreq[j], whenever i < j.
Types
-
Node
: No description provided. -
SymbolFreq
: No description provided.
</details><details> <summary> <strong> compression_test </strong> </summary>
Functions:
SymbolCountOrd
: SymbolCountOrd computes sorted symbol-frequency list of input message
</details><details> <summary> <strong> conversion </strong> </summary>
Package conversion is a package of implementations which converts one data structure to another.
Functions:
Base64Decode
: Base64Decode decodes the received input base64 string into a byte slice. The implementation follows the RFC4648 standard, which is documented at https://datatracker.ietf.org/doc/html/rfc4648#section-4Base64Encode
: Base64Encode encodes the received input bytes slice into a base64 string. The implementation follows the RFC4648 standard, which is documented at https://datatracker.ietf.org/doc/html/rfc4648#section-4BinaryToDecimal
: BinaryToDecimal() function that will take Binary number as string, and return its Decimal equivalent as integer.DecimalToBinary
: DecimalToBinary() function that will take Decimal number as int, and return its Binary equivalent as string.FuzzBase64Encode
: No description provided.HEXToRGB
: HEXToRGB splits an RGB input (e.g. a color in hex format; 0x<color-code>) into the individual components: red, green and blueIntToRoman
: IntToRoman converts an integer value to a roman numeral string. An error is returned if the integer is not between 1 and 3999.RGBToHEX
: RGBToHEX does exactly the opposite of HEXToRGB: it combines the three components red, green and blue to an RGB value, which can be converted to e.g. HexReverse
: Reverse() function that will take string, and returns the reverse of that string.RomanToInt
: RomanToInt converts a roman numeral string to an integer. Roman numerals for numbers outside the range 1 to 3,999 will return an error. Nil or empty string return 0 with no error thrown.
</details><details> <summary> <strong> deque </strong> </summary>
Package deque implements a Double Ended Queue data structure.
Functions:
New
: New returns a new DoublyEndedQueue.
Types
DoublyEndedQueue
: No description provided.
</details><details> <summary> <strong> deque_test </strong> </summary>
Types
-
QueryStructure
: No description provided. -
TestCaseData
: No description provided.
</details><details> <summary> <strong> diffiehellman </strong> </summary>
Package diffiehellman implements Diffie-Hellman Key Exchange Algorithm for more information watch : https://www.youtube.com/watch?v=NmM9HA2MQGI
Functions:
GenerateMutualKey
: GenerateMutualKey : generates a mutual key that can be used by only alice and bob mutualKey = (shareKey^prvKey)%primeNumberGenerateShareKey
: GenerateShareKey : generates a key using client private key , generator and primeNumber this key can be made public shareKey = (g^key)%primeNumber
</details><details> <summary> <strong> dynamic </strong> </summary>
Package dynamic is a package of certain implementations of dynamically run algorithms.
Functions:
Abbreviation
: Returns true if it is possible to make a equals b (if b is an abbreviation of a), returns false otherwiseBin2
: Bin2 functionCoinChange
: CoinChange finds the number of possible combinations of coins of different values which can get to the target amount.CutRodDp
: CutRodDp solve the same problem using dynamic programmingCutRodRec
: CutRodRec solve the problem recursively: initial approachEditDistanceDP
: EditDistanceDP is an optimised implementation which builds on the ideas of the recursive implementation. We use dynamic programming to compute the DP table where dp[i][j] denotes the edit distance value of first[0..i-1] and second[0..j-1]. Time complexity is O(m * n) where m and n are lengths of the strings, first and second respectively.EditDistanceRecursive
: EditDistanceRecursive is a naive implementation with exponential time complexity.IsSubsetSum
: No description provided.Knapsack
: Knapsack solves knapsack problem return maxProfitLongestCommonSubsequence
: LongestCommonSubsequence functionLongestIncreasingSubsequence
: LongestIncreasingSubsequence returns the longest increasing subsequence where all elements of the subsequence are sorted in increasing orderLongestIncreasingSubsequenceGreedy
: LongestIncreasingSubsequenceGreedy is a function to find the longest increasing subsequence in a given array using a greedy approach. The dynamic programming approach is implemented alongside this one. Worst Case Time Complexity: O(nlogn) Auxiliary Space: O(n), where n is the length of the array(slice). Reference: https://www.geeksforgeeks.org/construction-of-longest-monotonically-increasing-subsequence-n-log-n/LpsDp
: LpsDp functionLpsRec
: LpsRec functionMatrixChainDp
: MatrixChainDp functionMatrixChainRec
: MatrixChainRec functionMax
: Max function - possible duplicateNthCatalanNumber
: NthCatalan returns the n-th Catalan Number Complexity: O(n²)NthFibonacci
: NthFibonacci returns the nth Fibonacci NumberTrapRainWater
: Calculate the amount of trapped rainwater between bars represented by an elevation map using dynamic programming.
</details><details> <summary> <strong> dynamicarray </strong> </summary>
Package dynamicarray A dynamic array is quite similar to a regular array, but its Size is modifiable during program runtime, very similar to how a slice in Go works. The implementation is for educational purposes and explains how one might go about implementing their own version of slices. For more details check out those links below here: GeeksForGeeks article : https://www.geeksforgeeks.org/how-do-dynamic-arrays-work/ Go blog: https://blog.golang.org/slices-intro Go blog: https://blog.golang.org/slices authors Wesllhey Holanda, Milad see dynamicarray.go, dynamicarray_test.go
Types
DynamicArray
: No description provided.
</details><details> <summary> <strong> factorial </strong> </summary>
Package factorial describes algorithms Factorials calculations.
Functions:
Iterative
: Iterative returns the iteratively brute forced factorial of nRecursive
: Recursive This function recursively computes the factorial of a numberUsingTree
: UsingTree This function finds the factorial of a number using a binary tree
</details><details> <summary> <strong> fibonacci </strong> </summary>
Functions:
Formula
: Formula This function calculates the n-th fibonacci number using the formula Attention! Tests for large values fall due to rounding error of floating point numbers, works well, only on small numbersMatrix
: Matrix This function calculates the n-th fibonacci number using the matrix method. SeeRecursive
: Recursive calculates the n-th fibonacci number recursively by adding the previous two Fibonacci numbers. This algorithm is extremely slow for bigger numbers, but provides a simpler implementation.
</details><details> <summary> <strong> gcd </strong> </summary>
Functions:
Extended
: Extended simple extended gcdExtendedIterative
: ExtendedIterative finds and returns gcd(a, b), x, y satisfying ax + by = gcd(a, b).ExtendedRecursive
: ExtendedRecursive finds and returns gcd(a, b), x, y satisfying ax + by = gcd(a, b).Iterative
: Iterative Faster iterative version of GcdRecursive without holding up too much of the stackRecursive
: Recursive finds and returns the greatest common divisor of a given integer.TemplateBenchmarkExtendedGCD
: No description provided.TemplateBenchmarkGCD
: No description provided.TemplateTestExtendedGCD
: No description provided.TemplateTestGCD
: No description provided.
</details><details> <summary> <strong> generateparentheses </strong> </summary>
Functions:
GenerateParenthesis
: No description provided.
</details><details> <summary> <strong> genetic </strong> </summary>
Package genetic provides functions to work with strings using genetic algorithm. https://en.wikipedia.org/wiki/Genetic_algorithm Author: D4rkia
Functions:
GeneticString
: GeneticString generates PopulationItem based on the imputed target string, and a set of possible runes to build a string with. In order to optimise string generation additional configurations can be provided with Conf instance. Empty instance of Conf (&Conf{}) can be provided, then default values would be set. Link to the same algorithm implemented in python: https://github.com/TheAlgorithms/Python/blob/master/genetic_algorithm/basic_string.py
Types
-
Conf
: No description provided. -
PopulationItem
: No description provided. -
Result
: No description provided.
</details><details> <summary> <strong> geometry </strong> </summary>
Package geometry contains geometric algorithms Package geometry contains geometric algorithms
Functions:
Distance
: Distance calculates the shortest distance between two points.EuclideanDistance
: EuclideanDistance returns the Euclidean distance between points in anyn
dimensional Euclidean space.IsParallel
: IsParallel checks if two lines are parallel or not.IsPerpendicular
: IsPerpendicular checks if two lines are perpendicular or not.PointDistance
: PointDistance calculates the distance of a given Point from a given line. The slice should contain the coefficiet of x, the coefficient of y and the constant in the respective order.Section
: Section calculates the Point that divides a line in specific ratio. DO NOT specify the ratio in the form m:n, specify it as r, where r = m / n.Slope
: Slope calculates the slope (gradient) of a line.YIntercept
: YIntercept calculates the Y-Intercept of a line from a specific Point.
Types
-
EuclideanPoint
: No description provided. -
Line
: No description provided. -
Point
: No description provided.
</details><details> <summary> <strong> graph </strong> </summary>
Package graph demonstrates Graph search algorithms reference: https://en.wikipedia.org/wiki/Tree_traversal
Functions:
ArticulationPoint
: ArticulationPoint is a function to identify articulation points in a graph. The function takes the graph as an argument and returns a boolean slice which indicates whether a vertex is an articulation point or not. Worst Case Time Complexity: O(|V| + |E|) Auxiliary Space: O(|V|) reference: https://en.wikipedia.org/wiki/Biconnected_component and https://cptalks.quora.com/Cut-Vertex-Articulation-pointBreadthFirstSearch
: BreadthFirstSearch is an algorithm for traversing and searching graph data structures. It starts at an arbitrary node of a graph, and explores all of the neighbor nodes at the present depth prior to moving on to the nodes at the next depth level. Worst-case performance O(|V|+|E|)=O(b^{d})}O(|V|+|E|)=O(b^{d}) Worst-case space complexity O(|V|)=O(b^{d})}O(|V|)=O(b^{d}) reference: https://en.wikipedia.org/wiki/Breadth-first_searchDepthFirstSearch
: No description provided.DepthFirstSearchHelper
: No description provided.FloydWarshall
: FloydWarshall Returns all pair's shortest path using Floyd Warshall algorithmGetIdx
: No description provided.KruskalMST
: No description provided.PrimMST
: Computes the minimum spanning tree of a weighted undirected graphLowestCommonAncestor
: For each node, we will precompute its ancestor above him, its ancestor two nodes above, its ancestor four nodes above, etc. Let's calljump[j][u]
is the2^j
-th ancestor above the nodeu
withu
in range[0, numbersVertex)
,j
in range[0,MAXLOG)
. These information allow us to jump from any node to any ancestor above it inO(MAXLOG)
time.New
: Constructor functions for graphs (undirected by default)NewTree
: No description provided.NewUnionFind
: Initialise a new union find data structure with s nodesNotExist
: No description provided.Topological
: Topological assumes that graph given is valid and that its possible to get a topological ordering. constraints are array of []int{a, b}, representing an edge going from a to bEdmond-Karp
: Computes the maximum possible flow between a pair of s-t vertices in a weighted graph
Types
-
Edge
: No description provided. -
Graph
: No description provided. -
Item
: No description provided. -
Query
: No description provided. -
Tree
: No description provided. -
TreeEdge
: No description provided. -
UnionFind
: No description provided. -
WeightedGraph
: No description provided.
</details><details> <summary> <strong> guid </strong> </summary>
Package guid provides facilities for generating random globally unique identifiers.
Functions:
New
: New returns a randomly generated global unique identifier.
</details><details> <summary> <strong> hashmap </strong> </summary>
Functions:
Make
: Make creates a new HashMap instance with input size and capacityNew
: New return new HashMap instance
Types
HashMap
: No description provided.
</details><details> <summary> <strong> heap </strong> </summary>
Functions:
New
: New gives a new heap object.NewAny
: NewAny gives a new heap object. element can be anything, but must provide less function.
Types
Heap
: No description provided.
</details><details> <summary> <strong> heap_test </strong> </summary>
Types
</details><details> <summary> <strong> horspool </strong> </summary>
Functions:
Horspool
: No description provided.
</details><details> <summary> <strong> kmp </strong> </summary>
Functions:
Kmp
: Kmp Function kmp performing the Knuth-Morris-Pratt algorithm.
Types
args
: No description provided.
</details><details> <summary> <strong> lcm </strong> </summary>
Functions:
Lcm
: Lcm returns the lcm of two numbers using the fact that lcm(a,b) * gcd(a,b) = | a * b |
</details><details> <summary> <strong> levenshtein </strong> </summary>
Functions:
Distance
: Distance Function that gives Levenshtein Distance
</details><details> <summary> <strong> linkedlist </strong> </summary>
Package linkedlist demonstrates different implementations on linkedlists.
Functions:
JosephusProblem
: https://en.wikipedia.org/wiki/Josephus_problem This is a struct-based solution for Josephus problem.NewCyclic
: Create new list.NewDoubly
: No description provided.NewNode
: Create new node.NewSingly
: NewSingly returns a new instance of a linked list
Types
-
Cyclic
: No description provided. -
Doubly
: No description provided. -
Node
: No description provided. -
Singly
: No description provided. -
testCase
: No description provided.
</details><details> <summary> <strong> manacher </strong> </summary>
Functions:
LongestPalindrome
: No description provided.
</details><details> <summary> <strong> math </strong> </summary>
Package math is a package that contains mathematical algorithms and its different implementations. filename : krishnamurthy.go description: A program which contains the function that returns true if a given number is Krishnamurthy number or not. details: A number is a Krishnamurthy number if the sum of all the factorials of the digits is equal to the number. Ex: 1! = 1, 145 = 1! + 4! + 5! author(s): GooMonk see krishnamurthy_test.go
Functions:
Abs
: Abs returns absolute valueAliquotSum
: This function returns s(n) for given numberCombinations
: C is Binomial Coefficient function This function returns C(n, k) for given n and kCos
: Cos returns the cosine of the radian argument x. See more Based on the idea of Bhaskara approximation of cos(x)DefaultPolynomial
: DefaultPolynomial is the commonly used polynomial g(x) = (x^2 + 1) mod nFindKthMax
: FindKthMax returns the kth large element given an integer slice with nilerror
if found and returns -1 witherror
search.ErrNotFound
if not found. NOTE: Thenums
slice gets mutated in the process.FindKthMin
: FindKthMin returns kth small element given an integer slice with nilerror
if found and returns -1 witherror
search.ErrNotFound
if not found. NOTE: Thenums
slice gets mutated in the process.IsAutomorphic
: No description provided.IsKrishnamurthyNumber
: IsKrishnamurthyNumber returns if the provided number n is a Krishnamurthy number or not.IsPerfectNumber
: Checks if inNumber is a perfect numberIsPowOfTwoUseLog
: IsPowOfTwoUseLog This function checks if a number is a power of two using the logarithm. The limiting degree can be from 0 to 63. See alternatives in the binary package.Lerp
: Lerp or Linear interpolation This function will return new value in 't' percentage between 'v0' and 'v1'LiouvilleLambda
: Lambda is the liouville function This function returns λ(n) for given numberMean
: No description provided.Median
: No description provided.Mode
: No description provided.Mu
: Mu is the Mobius function This function returns μ(n) for given numberPhi
: Phi is the Euler totient function. This function computes the number of numbers less then n that are coprime with n.PollardsRhoFactorization
: PollardsRhoFactorization is an implementation of Pollard's rho factorization algorithm using the default parameters x = y = 2PronicNumber
: PronicNumber returns true if argument passed to the function is pronic and false otherwise.Sin
: Sin returns the sine of the radian argument x. See moreSumOfProperDivisors
: Returns the sum of proper divisors of inNumber.
</details><details> <summary> <strong> matrix </strong> </summary>
filename: strassenmatrixmultiply.go description: Implements matrix multiplication using the Strassen algorithm. details: This program takes two matrices as input and performs matrix multiplication using the Strassen algorithm, which is an optimized divide-and-conquer approach. It allows for efficient multiplication of large matrices. author(s): Mohit Raghav(https://github.com/mohit07raghav19) See strassenmatrixmultiply_test.go for test cases
Functions:
IsValid
: IsValid checks if the input matrix has consistent row lengths.New
: NewMatrix creates a new Matrix based on the provided arguments.NewFromElements
: NewFromElements creates a new Matrix from the given elements.
Types
Matrix
: No description provided.
</details><details> <summary> <strong> matrix_test </strong> </summary>
Functions:
MakeRandomMatrix
: No description provided.
</details><details> <summary> <strong> max </strong> </summary>
Functions:
Bitwise
: Bitwise computes using bitwise operator the maximum of all the integer input and returns itInt
: Int is a function which returns the maximum of all the integers provided as arguments.
</details><details> <summary> <strong> maxsubarraysum </strong> </summary>
Package maxsubarraysum is a package containing a solution to a common problem of finding max contiguous sum within a array of ints.
Functions:
MaxSubarraySum
: MaxSubarraySum returns the maximum subarray sum
</details><details> <summary> <strong> min </strong> </summary>
Functions:
Bitwise
: Bitwise This function returns the minimum integer using bit operationsInt
: Int is a function which returns the minimum of all the integers provided as arguments.
</details><details> <summary> <strong> modular </strong> </summary>
Functions:
Exponentiation
: Exponentiation returns base^exponent % modInverse
: Inverse Modular functionMultiply64BitInt
: Multiply64BitInt Checking if the integer multiplication overflows
</details><details> <summary> <strong> moserdebruijnsequence </strong> </summary>
Functions:
MoserDeBruijnSequence
: No description provided.
</details><details> <summary> <strong> nested </strong> </summary>
Package nested provides functions for testing strings proper brackets nesting.
Functions:
IsBalanced
: IsBalanced returns true if provided input string is properly nested. Input is a sequence of brackets: '(', ')', '[', ']', '{', '}'. A sequence of bracketss
is considered properly nested if any of the following conditions are true: -s
is empty; -s
has the form (U) or [U] or {U} where U is a properly nested string; -s
has the form VW where V and W are properly nested strings. For example, the string "()()[()]" is properly nested but "[(()]" is not. Note Providing characters other then brackets would return false, despite brackets sequence in the string. Make sure to filter input before usage.
</details><details> <summary> <strong> palindrome </strong> </summary>
Functions:
IsPalindrome
: No description provided.IsPalindromeRecursive
: No description provided.
</details><details> <summary> <strong> pangram </strong> </summary>
Functions:
IsPangram
: No description provided.
</details><details> <summary> <strong> parenthesis </strong> </summary>
Functions:
Parenthesis
: Parenthesis algorithm checks if every opened parenthesis is closed correctly. When parcounter is less than 0 when a closing parenthesis is detected without an opening parenthesis that surrounds it and parcounter will be 0 if all open parenthesis are closed correctly.
</details><details> <summary> <strong> pascal </strong> </summary>
Functions:
GenerateTriangle
: GenerateTriangle This function generates a Pascal's triangle of n lines
</details><details> <summary> <strong> password </strong> </summary>
Package password contains functions to help generate random passwords
Functions:
Generate
: Generate returns a newly generated password
</details><details> <summary> <strong> permutation </strong> </summary>
Functions:
GenerateElementSet
: No description provided.Heaps
: Heap's Algorithm for generating all permutations of n objectsNextPermutation
: A solution to find next permutation of an integer array in constant memory
</details><details> <summary> <strong> pi </strong> </summary>
spigotpi_test.go description: Test for Spigot Algorithm for the Digits of Pi author(s) red_byte see spigotpi.go
Functions:
MonteCarloPi
: No description provided.MonteCarloPiConcurrent
: MonteCarloPiConcurrent approximates the value of pi using the Monte Carlo method. Unlike the MonteCarloPi function (first version), this implementation uses goroutines and channels to parallelize the computation. More details on the Monte Carlo method available at https://en.wikipedia.org/wiki/Monte_Carlo_method. More details on goroutines parallelization available at https://go.dev/doc/effective_go#parallel.Spigot
: No description provided.
</details><details> <summary> <strong> polybius </strong> </summary>
Package polybius is encrypting method with polybius square ref: https://en.wikipedia.org/wiki/Polybius_square#Hybrid_Polybius_Playfair_Cipher
Functions:
FuzzPolybius
: No description provided.NewPolybius
: NewPolybius returns a pointer to object of Polybius. If the size of "chars" is longer than "size", "chars" are truncated to "size".
Types
Polybius
: No description provided.
</details><details> <summary> <strong> power </strong> </summary>
Functions:
IterativePower
: IterativePower is iterative O(logn) function for pow(x, y)RecursivePower
: RecursivePower is recursive O(logn) function for pow(x, y)RecursivePower1
: RecursivePower1 is recursive O(n) function for pow(x, y)UsingLog
: No description provided.
</details><details> <summary> <strong> prime </strong> </summary>
Functions:
Factorize
: Factorize is a function that computes the exponents of each prime in the prime factorization of nGenerate
: Generate returns a int slice of prime numbers up to the limitGenerateChannel
: Generate generates the sequence of integers starting at 2 and sends it to the channelch
MillerRabinDeterministic
: MillerRabinDeterministic is a Deterministic version of the Miller-Rabin test, which returns correct results for all valid int64 numbers.MillerRabinProbabilistic
: MillerRabinProbabilistic is a probabilistic test for primality of an integer based of the algorithm devised by Miller and Rabin.MillerRandomTest
: MillerRandomTest This is the intermediate step that repeats within the miller rabin primality test for better probabilitic chances of receiving the correct result with random witnesses.MillerTest
: MillerTest tests whether num is a strong probable prime to a witness. Formally: a^d ≡ 1 (mod n) or a^(2^r * d) ≡ -1 (mod n), 0 <= r <= sMillerTestMultiple
: MillerTestMultiple is like MillerTest but runs the test for multiple witnesses.OptimizedTrialDivision
: OptimizedTrialDivision checks primality of an integer using an optimized trial division method. The optimizations include not checking divisibility by the even numbers and only checking up to the square root of the given number.Sieve
: Sieve Sieving the numbers that are not prime from the channel - basically removing them from the channelsTrialDivision
: TrialDivision tests whether a number is prime by trying to divide it by the numbers less than it.Twin
: This function returns twin prime for given number returns (n + 2) if both n and (n + 2) are prime -1 otherwise
</details><details> <summary> <strong> pythagoras </strong> </summary>
Functions:
Distance
: Distance calculates the distance between to vectors with the Pythagoras theorem
Types
Vector
: No description provided.
</details><details> <summary> <strong> queue </strong> </summary>
Functions:
BackQueue
: BackQueue return the Back valueDeQueue
: DeQueue it will be removed the first value that added into the listEnQueue
: EnQueue it will be added new value into our listFrontQueue
: FrontQueue return the Front valueIsEmptyQueue
: IsEmptyQueue check our list is empty or notLenQueue
: LenQueue will return the length of the queue list
Types
</details><details> <summary> <strong> rot13 </strong> </summary>
Package rot13 is a simple letter substitution cipher that replaces a letter with the 13th letter after it in the alphabet. ref: https://en.wikipedia.org/wiki/ROT13
Functions:
FuzzRot13
: No description provided.
</details><details> <summary> <strong> rsa </strong> </summary>
Package rsa shows a simple implementation of RSA algorithm
Functions:
Decrypt
: Decrypt decrypts encrypted rune slice based on the RSA algorithmEncrypt
: Encrypt encrypts based on the RSA algorithm - uses modular exponentitation in math directoryFuzzRsa
: No description provided.
</details><details> <summary> <strong> search </strong> </summary>
Functions:
BoyerMoore
: Implementation of boyer moore string search O(l) where l=len(text)Naive
: Implementation of naive string search O(n*m) where n=len(txt) and m=len(pattern)
</details><details> <summary> <strong> segmenttree </strong> </summary>
Functions:
NewSegmentTree
: No description provided.
Types
SegmentTree
: No description provided.
</details><details> <summary> <strong> set </strong> </summary>
package set implements a Set using a golang map. This implies that only the types that are accepted as valid map keys can be used as set elements. For instance, do not try to Add a slice, or the program will panic.
Functions:
New
: New gives new set.
</details><details> <summary> <strong> sha256 </strong> </summary>
Functions:
Hash
: Hash hashes the input message using the sha256 hashing function, and return a 32 byte array. The implementation follows the RGC6234 standard, which is documented at https://datatracker.ietf.org/doc/html/rfc6234
</details><details> <summary> <strong> sort </strong> </summary>
Package sort a package for demonstrating sorting algorithms in Go
Functions:
BinaryInsertion
: No description provided.Bogo
: No description provided.Bubble
: Bubble is a simple generic definition of Bubble sort algorithm.Bucket
: Bucket sorts a slice. It is mainly useful when input is uniformly distributed over a range.Cocktail
: Cocktail sort is a variation of bubble sort, operating in two directions (beginning to end, end to beginning)Comb
: Comb is a simple sorting algorithm which is an improvement of the bubble sorting algorithm.Count
: No description provided.Cycle
: Cycle sort is an in-place, unstable sorting algorithm that is particularly useful when sorting arrays containing elements with a small range of values. It is theoretically optimal in terms of the total number of writes to the original array.Exchange
: No description provided.HeapSort
: No description provided.ImprovedSimple
: ImprovedSimple is a improve SimpleSort by skipping an unnecessary comparison of the first and last. This improved version is more similar to implementation of insertion sortInsertion
: No description provided.Merge
: Merge Perform merge sort on a sliceMergeIter
: No description provided.Pancake
: Pancake sorts a slice using flip operations, where flip refers to the idea of reversing the slice from index0
toi
.ParallelMerge
: ParallelMerge Perform merge sort on a slice using goroutinesPartition
: No description provided.Patience
: No description provided.Pigeonhole
: Pigeonhole sorts a slice using pigeonhole sorting algorithm. NOTE: To maintain time complexity O(n + N), this is the reason for having only Integer constraint instead of Ordered.Quicksort
: Quicksort Sorts the entire arrayQuicksortRange
: QuicksortRange Sorts the specified range within the arrayRadixSort
: No description provided.Selection
: No description provided.Shell
: No description provided.Simple
: No description provided.
Types
MaxHeap
: No description provided.
</details><details> <summary> <strong> sqrt </strong> </summary>
Package sqrt contains algorithms and data structures that contains a √n in their complexity
Functions:
NewSqrtDecomposition
: Create a new SqrtDecomposition instance with the parameters as specified by SqrtDecomposition comment Assumptions: - len(elements) > 0
Types
SqrtDecomposition
: No description provided.
</details><details> <summary> <strong> stack </strong> </summary>
Functions:
NewStack
: NewStack creates and returns a new stack.
Types
-
Array
: No description provided. -
Node
: No description provided. -
SList
: No description provided. -
Stack
: No description provided.
</details><details> <summary> <strong> strings </strong> </summary>
Package strings is a package that contains all algorithms that are used to analyse and manipulate strings.
Functions:
CountChars
: CountChars counts the number of a times a character has occurred in the provided string argument and returns a map withrune
as keys and the count as value.IsIsogram
: No description provided.IsSubsequence
: Returns true if s is subsequence of t, otherwise return false.
</details><details> <summary> <strong> transposition </strong> </summary>
Functions:
Decrypt
: No description provided.Encrypt
: No description provided.FuzzTransposition
: No description provided.
</details><details> <summary> <strong> tree </strong> </summary>
For more details check out those links below here: Wikipedia article: https://en.wikipedia.org/wiki/Binary_search_tree authors guuzaa
Functions:
NewAVL
: NewAVL creates a novel AVL treeNewBinarySearch
: NewBinarySearch creates a novel Binary-Search treeNewRB
: NewRB creates a new Red-Black Tree
Types
-
AVL
: No description provided. -
AVLNode
: No description provided. -
BSNode
: No description provided. -
BinarySearch
: No description provided. -
RB
: No description provided. -
RBNode
: No description provided.
</details><details> <summary> <strong> trie </strong> </summary>
Package trie provides Trie data structures in golang. Wikipedia: https://en.wikipedia.org/wiki/Trie
Functions:
NewNode
: NewNode creates a new Trie node with initialized children map.
Types
Node
: No description provided.
</details><details> <summary> <strong> xor </strong> </summary>
Package xor is an encryption algorithm that operates the exclusive disjunction(XOR) ref: https://en.wikipedia.org/wiki/XOR_cipher
Functions:
Decrypt
: Decrypt decrypts with Xor encryptionEncrypt
: Encrypt encrypts with Xor encryption after converting each character to byte The returned value might not be readable because there is no guarantee which is within the ASCII range If using other type such as string, []int, or some other types, add the statements for converting the type to []byte.FuzzXOR
: No description provided.
</details>
Package rail fence is a classical type of transposition cipher ref : https://en.wikipedia.org/wiki/Rail_fence_cipher
Functions:
Encrypt
: Encrypt encrypts a message using rail fence cipherDecrypt
: decrypt decrypts a message using rail fence cipherTestEncrypt
Test function for EncryptTestDecrypt
Test function for Decrypt
</details> <!--- GODOCMD END --->