Advertisement
Guest User

Untitled

a guest
Sep 17th, 2019
149
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.57 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2. #define endl '\n'
  3.  
  4. using namespace std;
  5.  
  6. template <typename T>
  7. void merge(T array[], int left, int pivot, int right, T aux[]) {
  8.     int i = left;
  9.     int j = pivot;
  10.  
  11.     for(int a = left; a < right; a++) {
  12.         aux[a] = array[a];
  13.     }
  14.  
  15.     for(int k = left; k < right; k++) {
  16.         if(i == pivot) {
  17.             array[k] = aux[j];
  18.             j++;
  19.         } else if (j == right) {
  20.             array[k] = aux[i];
  21.             i++;
  22.         } else {
  23.             if(aux[i] < aux[j]) {
  24.                 array[k] = aux[i];
  25.                 i++;
  26.             } else {
  27.                 array[k] = array[j];
  28.                 j++;
  29.             }
  30.         }
  31.     }
  32. }
  33.  
  34. template <typename T>
  35. void mergesort(T array[], int left, int right, T aux[]) {
  36.     if(left >= right) {
  37.         return;
  38.     }
  39.     int pivot = (left+right)/2;
  40.     mergesort(array, left, pivot, aux);
  41.     mergesort(array, pivot + 1, right, aux);
  42.     merge(array, left, pivot, right, aux);
  43. }
  44.  
  45. template <typename T>
  46. void mergesort(T array[]) {
  47.     T aux[sizeof(array)/sizeof(array[0])];
  48.     mergesort(array, 0, sizeof(array)/sizeof(array[0]), aux);
  49. }
  50.  
  51. int main(int argc, char *argv[]) {
  52.     ios::sync_with_stdio(false);
  53.     cin.tie(nullptr);
  54.  
  55.     int teste[] = { 5, 4, 2, 8, 9, 20 };
  56.  
  57.     for(int i = 0; i < sizeof(teste)/sizeof(teste[0]); i++) {
  58.         cout << teste[i] << '\t';
  59.     }
  60.     cout << endl;
  61.    
  62.     mergesort(teste);
  63.  
  64.     for(int i = 0; i < sizeof(teste)/sizeof(teste[0]); i++) {
  65.         cout << teste[i] << '\t';
  66.     }
  67.     cout << endl;
  68.  
  69.     return 0;
  70. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement