/Algorithms

A Repository for algorithms in C, C++, Python and Java

Primary LanguageC++Apache License 2.0Apache-2.0

image

A repository for all Algorithms



Programs we have been a part of

No. Program Name Duration Deployment
1. Hacktoberfest (2022) 1st Oct 2022 - 31st Oct 2022 Algorithm
2. Social Winter of Code (2023) 1st Jan 2023 - 10th Apr 2023 Algorithm


Available Resources

  • The resources are categorized based on programming language. One folder for one programming language

    • Each folder has different subfolders. The subfolder represents the category algorithm belongs to
      • Each subfolder has different files. Filename represents the name of the algorithm

No. Algorithm Name Available languages Category
1. Spiral Print Matrix C, Python Arrays
2. Caesar Cipher C, C++, Java, Python Cryptography
3. Diffie - Hellman Algorithm Cryptography
4. Railfence Cipher Python Cryptography
5. RSA Python Cryptography
6. SHA - 256 Cryptography
7. Vignere Cipher Python Cryptography
8. Huffman Coding C, C++, Java,Python Data Compression
9. Banker's Algorithm C, Python Deadlock Avoidance
10. Karatsuba Algorithm C++, Java, Python Divide and Conquer
11. Strassen's Matrix Multiplication C, Python Divide and Conquer
12. 0/1 Knapsack C, C++, Java, Python Dynamic Programming
13. Coin change problem C, C++, Java, Python Dynamic Programming
14. Edit Distance C++ Dynamic Programming
15. Longest Common Subsequence C++, Java Dynamic Programming
16. Matrix Chain Multiplication C++ Dynamic Programming
17. Minimum Jump Algorithm C, C++, Java, Python Dynamic Programming
18. Travelling Salesman Problem C Dynamic Programming
19. Bellman Ford C++ Graphs
20. Dijkstra C, C++, Java, Python Graphs
21. Dinic's Algorithm C++, Java, Python Graphs
22. Floyd Warshall C, C++, Java, Python Graphs
23. Kosaraju's Algorithm C++ Graphs
24. Prim's Algorithm C++, Java Graphs
25. Tarjan Algorithm C++ Graphs
26. Activity Selection C, C++, Java, Python Greedy Algorithm
27. Fractional Knapsack C, C++, Python Greedy Algorithm
28. Job Sequencing C++, Python Greedy Algorithm
29. Merge Interval Algorithm C, C++, Java, Python Greedy Algorithm
30. Addition of two Linked Lists C++ Linked List
31. Circular Linked List C, C++, Python Linked List
32. Doubly Linked List C++, Java, Python Linked List
33. Intersection of two Linked Lists C++ Linked List
34. LRU Cache Design C, C++, Java, Python Linked List
35. Merge Two Sorted Linked List C, C++, Java, Python Linked List
36. Palindrome Linked List C, C++, Java, Python Linked List
37. Reverse Linked List C, C++, Java, Python Linked List
38. Singly Linked List C, C++, Python Linked List
39. Decision Tree Python Machine Learning
40. K-Nearest Neighbours C++ Machine Learning
41. Linear Regression C++, Python Machine Learning
42. Logistic Regression C++, Python Machine Learning
43. Armstrong Numbers C, C++, Java, Python Maths
44. Binary Exponentiation C++ Maths
45. Bennett's Formula C, C++, Java, Python Maths
46. Bisection Algorithm C, C++, Java, Python Maths
47. Closures of Relations C, C++, Java, Python Maths
48. Decimal <-> Binary Converter C, Python Maths
49. Extended Euclidean Algorithm C, C++, Java, Python Maths
50. Factorial of Number C, C++, Java, Python Maths
51. Factors C, C++, Java, Python Maths
52. GCD & LCM C, C++, Java, Python Maths
53. Prefix-Postfix-Infix Interconversion C++, Python Maths
54. Prime Number C, C++, Java, Python Maths
55. Reverse Integer C++, Python Maths
56. Sieve Eratosthenes Algorithm C, C++, Java,Python Maths
57. KMP Algorithm Python Pattern Matching
58. Rabin Karp C++ Pattern Matching
59. Z - Algorithm C, C++, Java, Python Pattern Matching
60. BFS and DFS C++, Java Searching
61. Binary Search on 2D Matrix Java Searching
62. Binary Search C, C++, Java, Python Searching
63. Linear Search C, C++, Java, Python Searching
64. Order Agnostic Binary Search C++ Searching
65. Ternary Search C, C++, Java, Python Searching
66. Sliding Window Problems C++ Sliding Window
67. Bubble Sort C, C++, Java, Python Sorting
68. Bucket Sort C++ Sorting
69. Counting Sort C, C++, Python Sorting
70. Cyclic Sort C++, Java, Python Sorting
71. Cocktail Sort C++ Sorting
72. Dutch National Flag C++, Java, Python Sorting
73. Gnome Sort C, C++, Java, Python Sorting
74. Heap Sort C, C++, Java, Python Sorting
75. Insertion Sort C, C++, Java, Python Sorting
76. Merge Sort C, C++, Java, Python Sorting
77. Quick Sort C, C++ Sorting
78. Selection Sort C, C++, Java, Python Sorting
79. Topological Sort C++ Sorting
80. Wave Sort C++, Python Sorting
81. Max Area in Histogram C, C++, Java, Python Stacks
82. Next Greater Element C, C++, Java, Python Stacks
83. Rain Water Problem C, C++, Java, Python Stacks
84. Beautiful String Algorithm C, C++, Java, Python Strings
85. Camel Case Algorithm C, C++, Java, Python Strings
86. Boyer-Moore Majority Voting C, C++, Python Sub-Arrays
87. Kadane's Algorithm C++, Java, Python Sub-Arrays
88. AVL Tree C++, Java, Python Trees
89. Binary Search Tree C, C++ Trees
90. Binary Tree to BST C, C++, Java, Python Trees
91. Morris Traversal C, C++, Python Trees
92. Red-Black Tree C++, Python Trees
93. Tree Traversal C, C++, Java, Python Trees
94. Trie C++, Java Trees

Contributors 🫂


Steps for Contributing 🚀

Refer to this YouTube Video for reference!


  • Fork and clone the Repo by typing the following commands in the terminal
$ git clone https://github.com/Kumar-laxmi/Algorithms.git

$ cd Algorithms
  • Now to add your resource to website, add an object with keys same as listed in existing objects in the file.
  • Save and commit your code.
  • Push to your fork of the repository , navigate to original repository and make a pull request.

Screenshot 2022-10-23 at 8 03 11 AM
Screenshot 2022-10-23 at 8 03 31 AM
  • Clone the Repository after forking
$ git clone https://github.com/<your-github-username>/Algorithms.git

$ cd techsquad-community-website
  • Make changes to the code(for ex- add an update route)

  • Create a Branch using:

$ git checkout -b <branch-name>
  • Stage your changes using:
$ git add .
  • Commit your changes using:
$ git commit -m "add any comment"
  • Push the changes to the forked repository using:
$ git push origin <branch-name>
  • Navigate to the original repository and make a pull request
  • In case of merge conflict fetch and merge from the remote repository

Please don't forget to update the Available Resources section

Happy?? Star ⭐ this Repo. 🤩