-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMergeSort.h
More file actions
46 lines (37 loc) · 1.11 KB
/
MergeSort.h
File metadata and controls
46 lines (37 loc) · 1.11 KB
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
void merge(int *vetor,int inicio, int meio, int fim, int *vetorAux){
int iEsquerdo = inicio;
int iDireito = meio;
for (int i = inicio; i < fim ; i++){
if(iEsquerdo < meio and ((iDireito >=fim) or (vetor[iEsquerdo] < vetor[iDireito]))){
comparacoes++;
movimentacoes++;
vetorAux[i] = vetor[iEsquerdo];
iEsquerdo++;
}else{
comparacoes++;
movimentacoes++;
vetorAux[i] = vetor[iDireito];
iDireito++;
}
}
for(int i=inicio;i<fim;i++){
movimentacoes++;
vetor[i] = vetorAux[i];
}
}
void mergeSort(int vetor[], int inicio, int fim,int vetorAux[]){
if(fim - inicio >1){
comparacoes++;
int meio = (fim+inicio)/2;
movimentacoes++;
mergeSort(vetor,inicio,meio,vetorAux);
movimentacoes++;
mergeSort(vetor,meio,fim,vetorAux);
movimentacoes++;
merge(vetor,inicio,meio,fim,vetorAux);
}
}
void mergeSort(int vetor[], int tamanho){
int vetorAux[tamanho];
mergeSort(vetor,0,tamanho,vetorAux);
}