-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSerialSort.h
executable file
·76 lines (65 loc) · 1.81 KB
/
SerialSort.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
/*
* SequentialSort.h
*
* Created on: 29 giu 2018
* Author: rodolfo
*
* Algoritmi di ordinamento (SERIALI) serviranno per essere
* utilizzati come metriche di paragone e come supporto per
* gli algoritmi paralleli
*/
#ifndef SERIALSORT_H_
#define SERIALSORT_H_
#include <stdio.h>
#include <stdlib.h>
#include "Settings.h"
/*
* Funzione di swap che non utilizza una terza variabile
*
* @param a primo dato
* @param b secondo dato
*/
void swap(double *a, double *b);
/*
* Algoritmo di ordinamento quadratico seriale
*
* @param array da ordinare
* @param size dimensione dell'array
*/
void serialQuadraticSort(double *array, long int size);
/*
* Quicksort seriale (ITERATIVO).
*
* @see { Lo utilizzeremo come metrica di paaragone principale
* perchè il quicksort è il migliore algoritmo seriale
* di ordinamento. }
*
* @param array da ordinare
* @param size dimensione dell'array
*
* FONTE : https://en.wikibooks.org/wiki/Algorithm_Implementation/Sorting/Quicksort
*/
void serialIterativeQuickSort(double *array, long int size);
/*
* Versione seriale (RICORSIVA) del quicksort
*
* @see { per un corretto funzionamento fare la chiamata iniziale con SIZE-1:
* serialRecursiveQuickSort(array, 0, SIZE-1) }
*
* @param array da ordinare
* @param in parte iniziale dell' array (da dove partire)
* @param fin parte finale dell' array (da dove finire)
*/
void serialRecursiveQuickSort(double *array, long int in, long int fin);
/*
* Fase di partizionamento del quicksort ricorsivo
*
* @param array da ordinare
* @param in parte iniziale dell' array (da dove partire)
* @param fin parte finale dell' array (da dove finire)
* @param pivot da passare
*
* @return pivotNuovo
*/
long int recursiveQuickSortPartition(double *array, long int in, long int fin, long int pivot);
#endif /* SERIALSORT_H_ */