From 0816bfcddd782fe3a9933b3ae8cc397fc9b8b456 Mon Sep 17 00:00:00 2001 From: Pranav Rustagi <57594891+Pranav-Rustagi@users.noreply.github.com> Date: Wed, 12 Oct 2022 06:55:25 +0530 Subject: [PATCH 1/8] chore(Javascript): single occurring element among duplicates (#969) --- algorithms/JavaScript/README.md | 1 + .../src/arrays/single-occurring-element.js | 18 ++++++++++++++++++ algorithms/JavaScript/src/index.js | 1 + 3 files changed, 20 insertions(+) create mode 100644 algorithms/JavaScript/src/arrays/single-occurring-element.js diff --git a/algorithms/JavaScript/README.md b/algorithms/JavaScript/README.md index 7222c11a..56159de7 100644 --- a/algorithms/JavaScript/README.md +++ b/algorithms/JavaScript/README.md @@ -3,6 +3,7 @@ ## Arrays - [Counting Inversions](src/arrays/counting-inversions.js) +- [Single Occurring Element](src/arrays/single-occurring-element.js) ## Linked Lists diff --git a/algorithms/JavaScript/src/arrays/single-occurring-element.js b/algorithms/JavaScript/src/arrays/single-occurring-element.js new file mode 100644 index 00000000..1c8da89d --- /dev/null +++ b/algorithms/JavaScript/src/arrays/single-occurring-element.js @@ -0,0 +1,18 @@ +// Problem: Given an array of integers, +// every element appears twice except for one. Find that single one. +// Space Complexity: O(1) +// Time Complexity: O(n) + +function singleOccurringElement(arr) { + let result = 0; + for (const el of arr) { + result ^= el; + } + return result; +} + +const arr = [2, 5, 7, 3, 1, 8, 8, 9, 4, 2, 7, 1, 4, 9, 5]; +console.log(singleOccurringElement(arr)); + +// Input: [2, 5, 7, 3, 1, 8, 8, 9, 4, 2, 7, 1, 4, 9, 5] +// Output: 3 diff --git a/algorithms/JavaScript/src/index.js b/algorithms/JavaScript/src/index.js index a599f73b..5264890b 100644 --- a/algorithms/JavaScript/src/index.js +++ b/algorithms/JavaScript/src/index.js @@ -1,5 +1,6 @@ // Arrays require('./arrays/counting-inversions'); +require('./arrays/single-occurring-element'); // Linked Lists require('./linked-lists/singly'); From 550e317a63a7eef5575ea23828a559cae8a80507 Mon Sep 17 00:00:00 2001 From: Aryan Rai <46575675+aryanrai2001@users.noreply.github.com> Date: Wed, 12 Oct 2022 07:08:53 +0530 Subject: [PATCH 2/8] docs(en): order the section alphabetically (#1007) --- docs/en/README.md | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/docs/en/README.md b/docs/en/README.md index 65b4a7cf..924afa1a 100644 --- a/docs/en/README.md +++ b/docs/en/README.md @@ -1,11 +1,17 @@ # Algorithms +## Backtracking +- [N-Queens](./Backtracking/N-Queens.md) + ## Lists - [Singly linked list](./Lists/singly-linked-list.md) - [Doubly linked list](./Lists/doubly-linked-list.md) -## Sorting +## Searching +- [Binary Search](./Searching/Binary-Search.MD) +- [Linear Search](./Searching/Linear-Search.md) +## Sorting - [Bubble Sort](./Sorting/Bubble-Sort.md) - [Merge Sort](./Sorting/Merge-Sort.md) - [Selection Sort](./Sorting/Selection-Sort.md) @@ -13,16 +19,13 @@ - [Heap Sort](./Sorting/Heap-Sort.md) - [Quick Sort](./Sorting/Quick-Sort.md) - [Cycle Sort](./Sorting/Cycle-Sort.md) +- [Radix Sort](./Sorting/Radix-Sort.md) ## Strings - - [Palindrome](./Strings/Palindrome.md) -## Searching - -- [Binary Search](./Searching/Binary-Search.MD) -- [Linear Search](./Searching/Linear-Search.md) +## Tree +- [Min Heap](./Tree/min-heap.md) ## Others - [How to add new algorithm documentation?](./CONTRIBUTING.md) From 35c870d05dd489820389e73f0b83578a9c522314 Mon Sep 17 00:00:00 2001 From: BiscuitCandy <70342294+BiscuitCandy@users.noreply.github.com> Date: Thu, 13 Oct 2022 18:08:36 +0530 Subject: [PATCH 3/8] chore(Python): add max sub array sum (#936) --- algorithms/Python/README.md | 1 + algorithms/Python/arrays/max_sub_array_sum.py | 32 +++++++++++++++++++ 2 files changed, 33 insertions(+) create mode 100644 algorithms/Python/arrays/max_sub_array_sum.py diff --git a/algorithms/Python/README.md b/algorithms/Python/README.md index 9bcc929b..a2949840 100644 --- a/algorithms/Python/README.md +++ b/algorithms/Python/README.md @@ -7,6 +7,7 @@ - [Missing Number](arrays/missing_number.py) - [Remove duplicate items](arrays/remove_duplicates_list.py) - [Dutch National Flag Algorithm](arrays/dutch_national_flag_algo.py) +- [Max Sub Array Sum](arrays/max_sub_array_sum.py) ## Linked Lists - [Doubly](linked_lists/doubly.py) diff --git a/algorithms/Python/arrays/max_sub_array_sum.py b/algorithms/Python/arrays/max_sub_array_sum.py new file mode 100644 index 00000000..96f0e1dd --- /dev/null +++ b/algorithms/Python/arrays/max_sub_array_sum.py @@ -0,0 +1,32 @@ +""" +Algorithm Name: Max Sum of Sub Array +Time Complexity: O(n) +Explanation: arr = [3, 2, -4, 9] +at the start of the algorithm +assign current sum (max_sum_curr) = max sum(max_sum) = arr[0] +(for) iterate from arr[1] to arr[n] and do + max_sum_curr = arr[i] if arr[i] > arr[i] + max_sum_curr + else + max_sum_curr = max_sum_curr + arr[i] + max_sum = max_sum if max_sum > max_sum_curr + else + max_sum = max_sum_curr +end +return max_sum +""" + +def max_sub_arr_sum(arr): + arr_size = len(arr) + max_sum = arr[0] + max_sum_curr = arr[0] + + for i in range(1, arr_size): + max_sum_curr = max(arr[i], max_sum_curr + arr[i]) + max_sum = max(max_sum, max_sum_curr) + + return max_sum + + +# print("Enter array of numbers (Ex: 1 2 3 4 for [1, 2, 3, 4])") +arr = [3, 2, -4, 9] # list(map(int, input().split())) +print("Maximum Sub Array Sum is", max_sub_arr_sum(arr)) From 1cc547fd8bddc3309d1bfdaf106bab701a232174 Mon Sep 17 00:00:00 2001 From: Virendra Carpenter <66617140+virendracarpenter@users.noreply.github.com> Date: Thu, 13 Oct 2022 18:12:33 +0530 Subject: [PATCH 4/8] chore(CPlusPlus): add balanced parenthesis problem (#930) --- .../CPlusPlus/Arrays/balanced-parenthesis.cpp | 70 +++++++++++++++++++ algorithms/CPlusPlus/README.md | 2 +- 2 files changed, 71 insertions(+), 1 deletion(-) create mode 100644 algorithms/CPlusPlus/Arrays/balanced-parenthesis.cpp diff --git a/algorithms/CPlusPlus/Arrays/balanced-parenthesis.cpp b/algorithms/CPlusPlus/Arrays/balanced-parenthesis.cpp new file mode 100644 index 00000000..3f271bed --- /dev/null +++ b/algorithms/CPlusPlus/Arrays/balanced-parenthesis.cpp @@ -0,0 +1,70 @@ +#include +using namespace std; + +bool areBracketsBalanced (string expr) +{ + + stack < char >s; + char x; + + + // Traversing the Expression + for (int i = 0; i < expr.length (); i++) + if (expr[i] == '(' || expr[i] == '[' ||expr[i] == '{') + { + // Push the element in the stack + s.push (expr[i]); + continue; + } + + // IF current current character is not opening + // bracket, then it must be closing. So stack + // cannot be empty at this point. + + if (s.empty ()) + return false; + +switch (expr[i]) +{ + + case ')': // Store the top element in a + x = s.top (); + s.pop (); + + if (x == '{' || x == '[') + return false; + + break; + +case '}': // Store the top element in b + x = s.top (); + s.pop (); + if (x == '(' || x == '[') + return false; + break; +case ']': x = s.top (); + s.pop (); + if (x == '(' || x == '{') + return false; + break; + } + } +return (s.empty ()); +} +// Driver code +int main () +{ + string expr = "{()}[]"; + // Function call + if (areBracketsBalanced (expr)) + cout << "Balanced"; +else + cout << "Not Balanced"; + return 0; +} + +// Output:- +// Enter the brackets to check if its balanced or not : [{}] +// Balanced +// Enter the brackets to check if its balanced or not : {] +Not Balanced diff --git a/algorithms/CPlusPlus/README.md b/algorithms/CPlusPlus/README.md index 1de7183a..44469338 100644 --- a/algorithms/CPlusPlus/README.md +++ b/algorithms/CPlusPlus/README.md @@ -31,7 +31,7 @@ - [Next permutation](Arrays/next-permutation.cpp) - [Maximum Minimum Average of numbers](Arrays/max-min-avg.cpp) - [Sparse Matrix](Arrays/sparse_matrix.cpp) - +- [Balanced Parenthesis](Arrays/balanced-parenthesis.cpp) ## Dynamic-Programming From 9aae0fe5ea02f1bc1b2a4766307549145195a885 Mon Sep 17 00:00:00 2001 From: Jyoti Singh <98025162+dev24il@users.noreply.github.com> Date: Sat, 15 Oct 2022 21:22:10 +0530 Subject: [PATCH 5/8] chore(CPlusPlus): add rod cutting problem (#985) * Rod cutting in cpp completed * Update rod-cutting.cpp --- .../Dynamic-Programming/rod-cutting.cpp | 76 +++++++++++++++++++ algorithms/CPlusPlus/README.md | 1 + 2 files changed, 77 insertions(+) create mode 100644 algorithms/CPlusPlus/Dynamic-Programming/rod-cutting.cpp diff --git a/algorithms/CPlusPlus/Dynamic-Programming/rod-cutting.cpp b/algorithms/CPlusPlus/Dynamic-Programming/rod-cutting.cpp new file mode 100644 index 00000000..40e2b876 --- /dev/null +++ b/algorithms/CPlusPlus/Dynamic-Programming/rod-cutting.cpp @@ -0,0 +1,76 @@ +// Rod Cutting Problem +// Given a rod of length n and a list of rod prices of length i, where 1 <= i <= n, find the optimal way to cut the rod into smaller rods to maximize profit. + +// Rod Cutting Optimal Approach +// We will solve this problem in a bottom-up manner. (iteratively) +// In the bottom-up approach, we solve smaller subproblems first, then move on to larger subproblems. +// The following bottom-up approach computes dp[i], which stores maximum profit achieved from the rod of length i from 1 to len. +// It uses the value of smaller values i already computed. + +// Space complexity: O(n) +// Time complexity: O(n^n) + + +// Solution +#include +#include +#include + +using namespace std; + +// Function to find the maximum revenue from cutting a rod of length (len) +// where the rod of length (i) has cost (prices[i - 1]) +int RodCutting(vector &prices, int len) +{ + // (dp) stores the maximum revenue achieved from cutting a rod of length (from 1 to len) + vector dp(len + 1, 0); + // If the rod length is negative (invalid) or zero there's no revenue from it + if (len <= 0) + { + return 0; + } + // Cut a rod of length (i) + for (int i = 1; i <= len; i++) + { + // divide the rod of length (i) into two rods of lengths (j) and (i - j) + // and store the maximum revenue + for (int j = 0; j < i; j++) + { + // (dp[i]) stores the maximum revenue achieved from cutting a rod of length (i) + dp[i] = max(dp[i], prices[j] + dp[i - j - 1]); + } + } + // (dp[len]) contains the maximum revenue from cutting a rod of length (len) + return dp[len]; +} + +int main() +{ + int len; + cout << "Enter the rod length :"; + cin >> len; + + vector prices(len); + for (int i = 1; i <= len; i++) + { + cout << "Enter the price of the rod of length " << i << " :"; + cin >> prices[i - 1]; + } + + cout << "Maximum revenue = " << RodCutting(prices, len); + return 0; +} + + +// Input and output: +// 1. prices[] = [1, 5, 8, 9, 10, 17, 17, 20] +// rod length = 4 +// Best: Cut the rod into two pieces of length 2 each to gain revenue of 5 + 5 = 10 + +// 2. prices[] = [1, 5, 8, 9, 10, 17, 17, 20] +// rod length = 8 +// Best: Cut the rod into two pieces of length 2 and 6 to gain revenue of 5 + 17 = 22 + +// 3. prices[] = [3, 5, 8, 9, 10, 17, 17, 20] +// rod length = 8 +// Best: Cut the rod into eight pieces of length 1 to gain revenue of 8 * 3 = 24 diff --git a/algorithms/CPlusPlus/README.md b/algorithms/CPlusPlus/README.md index 44469338..a5cca706 100644 --- a/algorithms/CPlusPlus/README.md +++ b/algorithms/CPlusPlus/README.md @@ -42,6 +42,7 @@ - [Matrix chain Multiplication](Dynamic-Programming/matrix-chain-multiplication.cpp) - [Edit Distance](Dynamic-Programming/edit-distance.cpp) - [Fibonacci](Dynamic-Programming/fibonacci.cpp) +- [Rod Cutting](Dynamic-Programming/rod-cutting.cpp) ## Graphs From 4fc4e6e25b943efcd362c85294a2fd4767f1313f Mon Sep 17 00:00:00 2001 From: ashwath462 <79273144+ashwath462@users.noreply.github.com> Date: Sun, 16 Oct 2022 06:02:12 +0530 Subject: [PATCH 6/8] chore(CPlusCPlus): add trie algorithms (#1006) --- algorithms/CPlusPlus/README.md | 2 + algorithms/CPlusPlus/Trie/trie_delete.cpp | 44 +++++++++++++++++++ .../Trie/trie_insert_search_startWith.cpp | 44 +++++++++++++++++++ 3 files changed, 90 insertions(+) create mode 100644 algorithms/CPlusPlus/Trie/trie_delete.cpp create mode 100644 algorithms/CPlusPlus/Trie/trie_insert_search_startWith.cpp diff --git a/algorithms/CPlusPlus/README.md b/algorithms/CPlusPlus/README.md index a5cca706..8b3d72ed 100644 --- a/algorithms/CPlusPlus/README.md +++ b/algorithms/CPlusPlus/README.md @@ -157,6 +157,8 @@ ## Trie - [Trie for searching](Trie/trie_search.cpp) +- [Trie for insert search and prefix_search](Trie/trie_insert_search_startWith.cpp) +- [Trie for delete](Trie/trie_delete.cpp) # Maths diff --git a/algorithms/CPlusPlus/Trie/trie_delete.cpp b/algorithms/CPlusPlus/Trie/trie_delete.cpp new file mode 100644 index 00000000..86ea5f9b --- /dev/null +++ b/algorithms/CPlusPlus/Trie/trie_delete.cpp @@ -0,0 +1,44 @@ +#include +using namespace std; +typedef long long ll; +#define inf 1e9; +#define inf2 2e18; + + + +struct custom_hash { + static uint64_t splitmix64(uint64_t x) { x += 0x9e3779b97f4a7c15; x = (x ^ (x >> 30)) * 0xbf58476d1ce4e5b9; x = (x ^ (x >> 27)) * 0x94d049bb133111eb; return x ^ (x >> 31);} + size_t operator()(uint64_t x) const { static const uint64_t FIXED_RANDOM = chrono::steady_clock::now().time_since_epoch().count(); return splitmix64(x + FIXED_RANDOM); } +}; + + + +struct TrieNode{ TrieNode* child[26]; bool isEnd; + TrieNode(){ isEnd = false; for(int i = 0; i<26; i++){ child[i] = NULL; } } +}; +struct TrieNode* rootTrie; +void addTrie(string& s){ TrieNode* curr = rootTrie; for(int i = 0; ichild[n] == NULL){curr->child[n] = new TrieNode();} curr = curr->child[n]; } curr->isEnd = true; } +bool searchTrie(string& s){TrieNode* curr = rootTrie;for(int i = 0; ichild[n]) return false;curr = curr->child[n];}return curr->isEnd;} +bool startsWithTrie(string s) {int n = s.length();TrieNode* curr = rootTrie;for(int i =0 ; ichild[k] == NULL) return false;curr = curr->child[k];}return true;} +bool isEmpty(TrieNode* rootTrie){ for (int i = 0; i < ALPHABET_SIZE; i++){if(rootTrie->child[i])return false;}return true;} +void remove(TrieNode* rootTrie, string key, int depth = 0){if (!rootTrie)return NULL;if (depth == key.size()) {if (rootTrie->isEnd)rootTrie->isEnd = false;if (isEmpty(rootTrie)) {delete (rootTrie);rootTrie = NULL;}return rootTrie;}int index = key[depth] - 'a';rootTrie->child[index] = remove(rootTrie->child[index], key, depth + 1);if (isEmpty(rootTrie) && rootTrie->isEnd == false) {delete (rootTrie);rootTrie = NULL;}return rootTrie;} + + +int main(){ +//Jai Shree Ram + ios_base::sync_with_stdio(false); + cin.tie(NULL); + + string keys[] = { "the", "a", "there", "answer", "any", "by", "bye", "their", "hero", "heroplane" }; + int n = sizeof(keys) / sizeof(keys[0]); + + for (int i = 0; i < n; i++) + insert(rootTrie, keys[i]); + + search(rootTrie, "the") ? cout << "Yes\n" : cout << "No\n"; + search(rootTrie, "these") ? cout << "Yes\n" : cout << "No\n"; + + remove(rootTrie, "heroplane"); + search(rootTrie, "hero") ? cout << "Yes\n" : cout << "No\n"; + return 0; +} \ No newline at end of file diff --git a/algorithms/CPlusPlus/Trie/trie_insert_search_startWith.cpp b/algorithms/CPlusPlus/Trie/trie_insert_search_startWith.cpp new file mode 100644 index 00000000..8c73a57c --- /dev/null +++ b/algorithms/CPlusPlus/Trie/trie_insert_search_startWith.cpp @@ -0,0 +1,44 @@ +#include +using namespace std; +typedef long long ll; +#define inf 1e9; +#define inf2 2e18; + + + +struct custom_hash { + static uint64_t splitmix64(uint64_t x) { x += 0x9e3779b97f4a7c15; x = (x ^ (x >> 30)) * 0xbf58476d1ce4e5b9; x = (x ^ (x >> 27)) * 0x94d049bb133111eb; return x ^ (x >> 31);} + size_t operator()(uint64_t x) const { static const uint64_t FIXED_RANDOM = chrono::steady_clock::now().time_since_epoch().count(); return splitmix64(x + FIXED_RANDOM); } +}; + + + +struct TrieNode{ TrieNode* child[26]; bool isEnd; + TrieNode(){ isEnd = false; for(int i = 0; i<26; i++){ child[i] = NULL; } } +}; +struct TrieNode* rootTrie; +void addTrie(string& s){ TrieNode* curr = rootTrie; for(int i = 0; ichild[n] == NULL){curr->child[n] = new TrieNode();} curr = curr->child[n]; } curr->isEnd = true; } +bool searchTrie(string& s){TrieNode* curr = rootTrie;for(int i = 0; ichild[n]) return false;curr = curr->child[n];}return curr->isEnd;} +bool startsWithTrie(string s) {int n = s.length();TrieNode* curr = rootTrie;for(int i =0 ; ichild[k] == NULL) return false;curr = curr->child[k];}return true;} + + + +int main(){ +//Jai Shree Ram + ios_base::sync_with_stdio(false); + cin.tie(NULL); + + string keys[] = {"the", "a", "there", "answer", "any", "by", "bye", "their" }; + int n = sizeof(keys)/sizeof(keys[0]); + struct TrieNode *root = getNode(); + + for (int i = 0; i < n; i++) insert(root, keys[i]); + + char output[][32] = {"Not present in trie", "Present in trie"}; + + cout<<"the"<<" --- "< Date: Sat, 15 Oct 2022 20:34:38 -0400 Subject: [PATCH 7/8] fix(CPlusPlus): spelling problem --- algorithms/CPlusPlus/Arrays/max-subarray-sum.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/algorithms/CPlusPlus/Arrays/max-subarray-sum.cpp b/algorithms/CPlusPlus/Arrays/max-subarray-sum.cpp index 98100664..df8872fd 100644 --- a/algorithms/CPlusPlus/Arrays/max-subarray-sum.cpp +++ b/algorithms/CPlusPlus/Arrays/max-subarray-sum.cpp @@ -20,7 +20,7 @@ int maxSubArrSum_A(int a[],int n){ return maxSum; } -// Appraoch B - Cumulative Sum Approach O(n^2) +// Approach B - Cumulative Sum Approach O(n^2) int maxSubArrSum_B(int a[],int n){ int currSum[n+1]; currSum[0] = 0; for(int i=1;i<=n;++i){ @@ -66,4 +66,4 @@ int main(){ cout< Date: Sun, 16 Oct 2022 02:51:58 +0200 Subject: [PATCH 8/8] chore(codespell): upgrade Github action (#1040) --- .github/workflows/codespell.yml | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/.github/workflows/codespell.yml b/.github/workflows/codespell.yml index 3db88c38..c5005fed 100644 --- a/.github/workflows/codespell.yml +++ b/.github/workflows/codespell.yml @@ -8,7 +8,9 @@ jobs: codespell: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 - - uses: actions/setup-python@v2 + - uses: actions/checkout@v3 + - uses: actions/setup-python@v4 + with: + python-version: 3.x - run: pip install codespell - run: codespell --ignore-words-list="ans,nnumber,nin,Hel" --quiet-level=2 --skip="**/**/package-lock.json,./docs/pt,./docs/es,./docs/tr,./.github,./algorithms/CSharp/test"