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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <vector>
#define SWAP(a,b,t)(t=a,a=b,b=t)
using namespace std;
vector< int > inp[5];
void quicksort(int left, int right, int idx) {
int tmp;
if(left<right){
int pivot = left;
int i = left, j = right+1;
while(i<=j) {
do {
i++;
}while(inp[idx][pivot]>inp[idx][i] && i<=right);
do{
j--;
}while(inp[idx][pivot]<inp[idx][j] && j>=left);
if(i<j) SWAP(inp[idx][i], inp[idx][j], tmp);
}
SWAP(inp[idx][pivot], inp[idx][j], tmp);
quicksort(left, j-1, idx);
quicksort(j+1, right, idx);
}
}
void insertsort(int n, int idx) {
for(int i=1;i<n;i++) {
int tmp = inp[idx][i];
int j = i;
while(tmp<inp[idx][j-1] && j>0) {
inp[idx][j] = inp[idx][j-1];
j--;
}
inp[idx][j] = tmp;
}
}
void selectionsort(int n, int idx) {
int tmp;
for(int i=0;i<n-1;i++) {
for(int j=i+1;j<n;j++) {
if(inp[idx][i] > inp[idx][j]) SWAP(inp[idx][i], inp[idx][j], tmp);
}
}
}
void bubblesort(int n, int idx) {
int tmp;
for(int i=1;i<=n;i++) {
for(int j=0;j<n-i;j++) {
if(inp[idx][j] > inp[idx][j+1]) SWAP(inp[idx][j], inp[idx][j+1], tmp);
}
}
}
int main() {
int n, st;
srand(time(NULL));
printf("데이터의 개수를 입력하세요: "); scanf("%d", &n);
for(int i=0;i<n;i++) {
int t = rand();
for(int idx=0;idx<5;idx++) inp[idx].push_back(t);
}
st = clock();
quicksort(0, n-1, 0);
printf("퀵정렬: %.2lf(sec)\n", (double)(clock() - st)/CLOCKS_PER_SEC);
st = clock();
insertsort(n, 1);
printf("삽입정렬: %.2lf(sec)\n", (double)(clock() - st)/CLOCKS_PER_SEC);
st = clock();
bubblesort(n, 2);
printf("버블정렬: %.2lf(sec)\n", (double)(clock() - st)/CLOCKS_PER_SEC);
st = clock();
selectionsort(n, 3);
printf("선택정렬: %.2lf(sec)", (double)(clock() - st)/CLOCKS_PER_SEC);
}
|
cs |
'Study' 카테고리의 다른 글
람다식을 활용한 중첩 반복문 탈출( BOJ 20410 ) (0) | 2022.07.11 |
---|---|
모듈로 곱셈 역원_팩토리얼 계산( BOJ 13977 ) (0) | 2022.07.11 |
소수 판별법(밀러-라빈 소수판별법) (0) | 2022.02.09 |
순열 알고리즘 (0) | 2021.10.01 |
Manacher's Algorithm (0) | 2021.05.27 |