From 95f667f4492f45c268dc0b8de33356444e5501f6 Mon Sep 17 00:00:00 2001 From: Aditya Bhandari <45709057+adityabhandari15@users.noreply.github.com> Date: Thu, 31 Oct 2019 18:17:18 +0530 Subject: [PATCH 1/4] Create GnomeSort.cpp --- GnomeSort.cpp | 41 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 GnomeSort.cpp diff --git a/GnomeSort.cpp b/GnomeSort.cpp new file mode 100644 index 0000000..8897768 --- /dev/null +++ b/GnomeSort.cpp @@ -0,0 +1,41 @@ +#include +using namespace std; + +// A function to sort the algorithm using gnome sort +void gnomeSort(int arr[], int n) +{ + int index = 0; + + while (index < n) { + if (index == 0) + index++; + if (arr[index] >= arr[index - 1]) + index++; + else { + swap(arr[index], arr[index - 1]); + index--; + } + } + return; +} + +// A utility function ot print an array of size n +void printArray(int arr[], int n) +{ + cout << "Sorted sequence after Gnome sort: "; + for (int i = 0; i < n; i++) + cout << arr[i] << " "; + cout << "\n"; +} + +// Driver program to test above functions. +int main() +{ + int arr[] = { 34, 2, 10, -9 }; + int n = sizeof(arr) / sizeof(arr[0]); + + gnomeSort(arr, n); + printArray(arr, n); + + return (0); +} From d01d1a7401313075092c0307b890d14cf272f878 Mon Sep 17 00:00:00 2001 From: Aditya Bhandari <45709057+adityabhandari15@users.noreply.github.com> Date: Thu, 31 Oct 2019 18:17:42 +0530 Subject: [PATCH 2/4] Delete GnomeSort.cpp --- GnomeSort.cpp | 41 ----------------------------------------- 1 file changed, 41 deletions(-) delete mode 100644 GnomeSort.cpp diff --git a/GnomeSort.cpp b/GnomeSort.cpp deleted file mode 100644 index 8897768..0000000 --- a/GnomeSort.cpp +++ /dev/null @@ -1,41 +0,0 @@ -#include -using namespace std; - -// A function to sort the algorithm using gnome sort -void gnomeSort(int arr[], int n) -{ - int index = 0; - - while (index < n) { - if (index == 0) - index++; - if (arr[index] >= arr[index - 1]) - index++; - else { - swap(arr[index], arr[index - 1]); - index--; - } - } - return; -} - -// A utility function ot print an array of size n -void printArray(int arr[], int n) -{ - cout << "Sorted sequence after Gnome sort: "; - for (int i = 0; i < n; i++) - cout << arr[i] << " "; - cout << "\n"; -} - -// Driver program to test above functions. -int main() -{ - int arr[] = { 34, 2, 10, -9 }; - int n = sizeof(arr) / sizeof(arr[0]); - - gnomeSort(arr, n); - printArray(arr, n); - - return (0); -} From 51a683d7eb4c52d2876caf6faca899e7bd50351e Mon Sep 17 00:00:00 2001 From: Aditya Bhandari <45709057+adityabhandari15@users.noreply.github.com> Date: Thu, 31 Oct 2019 18:18:10 +0530 Subject: [PATCH 3/4] Create GnomeSort.cpp --- Sorting/GnomeSort.cpp | 41 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 Sorting/GnomeSort.cpp diff --git a/Sorting/GnomeSort.cpp b/Sorting/GnomeSort.cpp new file mode 100644 index 0000000..8897768 --- /dev/null +++ b/Sorting/GnomeSort.cpp @@ -0,0 +1,41 @@ +#include +using namespace std; + +// A function to sort the algorithm using gnome sort +void gnomeSort(int arr[], int n) +{ + int index = 0; + + while (index < n) { + if (index == 0) + index++; + if (arr[index] >= arr[index - 1]) + index++; + else { + swap(arr[index], arr[index - 1]); + index--; + } + } + return; +} + +// A utility function ot print an array of size n +void printArray(int arr[], int n) +{ + cout << "Sorted sequence after Gnome sort: "; + for (int i = 0; i < n; i++) + cout << arr[i] << " "; + cout << "\n"; +} + +// Driver program to test above functions. +int main() +{ + int arr[] = { 34, 2, 10, -9 }; + int n = sizeof(arr) / sizeof(arr[0]); + + gnomeSort(arr, n); + printArray(arr, n); + + return (0); +} From 725808ba81b44f7388071c5f6e7de18dfe00e273 Mon Sep 17 00:00:00 2001 From: Aditya Bhandari <45709057+adityabhandari15@users.noreply.github.com> Date: Thu, 31 Oct 2019 18:24:23 +0530 Subject: [PATCH 4/4] Create Prefix-Sum-Array A program to find if there exists a subrray with sum=0, using Prefix-sum-array --- Arrays/Prefix-Sum-Array | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 Arrays/Prefix-Sum-Array diff --git a/Arrays/Prefix-Sum-Array b/Arrays/Prefix-Sum-Array new file mode 100644 index 0000000..ac307f9 --- /dev/null +++ b/Arrays/Prefix-Sum-Array @@ -0,0 +1,35 @@ +// A C++ program to find if there is a zero sum +// subarray +#include +using namespace std; + +bool subArrayExists(int arr[], int n) +{ + unordered_set sumSet; + + // Traverse through array and store prefix sums + int sum = 0; + for (int i = 0 ; i < n ; i++) + { + sum += arr[i]; + + // If prefix sum is 0 or it is already present + if (sum == 0 || sumSet.find(sum) != sumSet.end()) + return true; + + sumSet.insert(sum); + } + return false; +} + +// Driver code +int main() +{ + int arr[] = {-3, 2, 3, 1, 6}; + int n = sizeof(arr)/sizeof(arr[0]); + if (subArrayExists(arr, n)) + cout << "Found a subarray with 0 sum"; + else + cout << "No Such Sub Array Exists!"; + return 0; +}