Thiff

Threads_mergefunctions

Nov 13th, 2017
28
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.58 KB | None | 0 0
  1. #include <iostream>
  2. #include <time.h>
  3. #include <windows.h>
  4.  
  5. using namespace std;
  6.  
  7. char *pole;
  8. int dlzka;
  9.  
  10. void bubble_sort(int, int);
  11.  
  12. char generateChar(int min, int max) {
  13.     return rand() % (max - min) + min;
  14. }
  15.  
  16. int kolik_ms( LPFILETIME pred, LPFILETIME po )
  17. {
  18.     hyper pred64b = pred->dwHighDateTime;
  19.     pred64b = ( pred64b << 32 ) | pred->dwLowDateTime;
  20.     hyper po64b = po->dwHighDateTime;
  21.     po64b = ( po64b << 32 ) | po->dwLowDateTime;
  22.     // konverze 100ns -> 1ms
  23.     return ( int ) ( ( po64b - pred64b ) / 10000 );
  24. }
  25.  
  26. DWORD WINAPI vlaknoA( LPVOID r)
  27. {
  28.     int *r0 = (int *) r;
  29.     printf( "Vlakno\n" );
  30.     bubble_sort(r0[0],r0[1]);
  31.     return 0;
  32. }
  33.  
  34. void bubble_sort(int start, int end) {
  35.     int tmp;
  36.  
  37.     for(int i = start; i < end; i++) {
  38.         for(int j = start; j < end - (i-start) - 1; j++) {
  39.  
  40.             if (pole[j+1] > pole[j]) {
  41.                 tmp = pole[j+1];
  42.  
  43.                 pole[j+1] = pole[j];
  44.                 pole[j] = tmp;
  45.             }
  46.  
  47.         }
  48.  
  49.     }
  50. }
  51.  
  52. void otoc_pole() {
  53.     int tmp;
  54.  
  55.     for(int i = 0; i < dlzka/2; i++) {
  56.         tmp = pole[dlzka-1-i];
  57.         pole[dlzka-1-i] = pole[i];
  58.         pole[i] = tmp;
  59.     }
  60. }
  61.  
  62. void spoj_pole() {
  63.     char *novePole;
  64.     int start = 0;
  65.     int end = dlzka/2;
  66.  
  67.     int tmp1, tmp2;
  68.  
  69.     novePole = new char[dlzka];
  70.  
  71.     for(int i = 0; i < dlzka; i++) {
  72.  
  73.         if ((int)pole[start] > (int)pole[end]) {
  74.             if (start == dlzka/2) {
  75.                 novePole[i] = pole[end++];
  76.             }
  77.             else {
  78.                 novePole[i] = pole[start++];
  79.             }
  80.         }
  81.         else {
  82.             if (end == dlzka) {
  83.                 novePole[i] = pole[start];
  84.             }
  85.             else {
  86.                 novePole[i] = pole[end++];
  87.             }
  88.         }
  89.  
  90.     }
  91. }
  92.  
  93. int main() {
  94.     FILETIME cas_pred, cas_po;
  95.     HANDLE h1,h2,h3,h4;
  96.  
  97.     srand(time(NULL));
  98.  
  99.     int minimum = -60;
  100.     int maximum = 10;
  101.  
  102.     dlzka = 10;
  103.  
  104.     pole = new char[dlzka];
  105.  
  106.     for(int i = 0; i < dlzka; i++) {
  107.         pole[i] = generateChar(minimum, maximum);
  108.     }
  109.     printf("\nBubbleSort:\n");
  110.  
  111.     int r0[] = {0, dlzka/2};
  112.     int r1[] = {dlzka/2, dlzka};
  113.  
  114.     GetSystemTimeAsFileTime ( &cas_pred );
  115.     h1 = CreateThread(0, 0, vlaknoA, r0, 0, 0);
  116.     h2 = CreateThread(0, 0, vlaknoA, r1, 0, 0);
  117.  
  118.     WaitForSingleObject( h1, INFINITE );
  119.     WaitForSingleObject( h2, INFINITE );
  120.     GetSystemTimeAsFileTime ( &cas_po );
  121.  
  122.     printf("Zotriedenie trvalo: %dms \n", kolik_ms(&cas_pred, &cas_po));
  123.    
  124.     spoj_pole();
  125.  
  126.  
  127.     /*
  128.     otoc_pole();
  129.  
  130.     GetSystemTimeAsFileTime ( &cas_pred );
  131.     h3 = CreateThread(0, 0, vlaknoA, r0, 0, 0);
  132.     h4 = CreateThread(0, 0, vlaknoA, r1, 0, 0);
  133.  
  134.     WaitForSingleObject( h3, INFINITE );
  135.     WaitForSingleObject( h4, INFINITE );
  136.     GetSystemTimeAsFileTime ( &cas_po );
  137.  
  138.     printf("Zotriedenie prevrateneho pola trvalo: %dms \n", kolik_ms(&cas_pred, &cas_po));
  139.     */
  140.  
  141.     return 0;
  142.  
  143. }
Add Comment
Please, Sign In to add comment