-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsort.cpp
113 lines (95 loc) · 3.83 KB
/
sort.cpp
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
103
104
105
106
107
108
109
110
111
112
113
#include <iostream>
#include <chrono>
#include <cstring>
#include "sort_execute.hpp"
#include "DataGenerator.hpp"
#include "helpler.hpp"
#include "Experiment.hpp"
void executeFromCommandLine(int &argv, char **&argc) {
Experiment experiment;
// check compare mode or algorithm mode
if (strcmp(argc[1], "-c") == 0) {
experiment.isCompareMode = true;
}
else if (strcmp(argc[1], "-a") == 0) {
experiment.isCompareMode = false;
}
else {
std::cout << "Invalid mode: only -a for algorithm mode and -c for compare mode\n";
return;
}
// get input parameters
if (experiment.isCompareMode) {
experiment.algorithmID[0] = getAlgorithmID(argc[2]);
experiment.algorithmID[1] = getAlgorithmID(argc[3]);
experiment.isInputingFromFile = !is_number(argc[4]);
if (experiment.isInputingFromFile) {
std::string inputFileName = argc[4];
experiment.filename = inputFileName;
int readStatus = readArray(experiment.arrays[0], experiment.size, argc[4]);
// if read fail (file not exists)
if (readStatus == -1)
exit(1);
}
else {
experiment.size = atoi(argc[4]);
experiment.dataOrderID = getDataOrderID(argc[5]);
// dataOrder not exists
if (experiment.dataOrderID == -1) {
std::cout << "Wrong data order syntax\n";
std::cout << "syntax: -rand, -sorted, -rev, -nsorted\n";
return;
}
experiment.arrays[0] = new int[experiment.size];
GenerateData(experiment.arrays[0], experiment.size, experiment.dataOrderID);
char filename[] = "input.txt";
writeData(experiment.arrays[0], experiment.size, filename);
}
}
else {
experiment.algorithmID[0] = getAlgorithmID(argc[2]);
experiment.isInputingFromFile = !is_number(argc[3]);
if (experiment.isInputingFromFile) {
std::string inputFileName = argc[3];
experiment.filename = inputFileName;
int readStatus = readArray(experiment.arrays[0], experiment.size, argc[3]);
// if read fail (file not exists)
if (readStatus == -1)
exit(1);
experiment.outputParameter = getOutputParameterID(argc[4]);
}
else {
experiment.size = atoi(argc[3]);
experiment.isRunningAllDataOrder = isOutputParameterID(argc[4]);
if (experiment.isRunningAllDataOrder) {
experiment.outputParameter = getOutputParameterID(argc[4]);
for (int dataOrder_id = 0; dataOrder_id < NUMBER_DATA_ORDER; dataOrder_id++) {
experiment.arrays[dataOrder_id] = new int[experiment.size];
GenerateData(experiment.arrays[dataOrder_id], experiment.size, dataOrder_id);
char filename[] = "input_0.txt";
filename[6] = dataOrder_id + 1 + '0';
writeData(experiment.arrays[dataOrder_id], experiment.size, filename);
}
}
else {
experiment.dataOrderID = getDataOrderID(argc[4]);
experiment.outputParameter = getOutputParameterID(argc[5]);
experiment.arrays[0] = new int[experiment.size];
GenerateData(experiment.arrays[0], experiment.size, experiment.dataOrderID);
char filename[] = "input.txt";
writeData(experiment.arrays[0], experiment.size, filename);
}
}
}
if (experiment.isCompareMode) {
experiment.compareMode();
}
else {
experiment.algorithmMode();
}
experiment.printResult();
return;
}
int main(int argv, char **argc) {
executeFromCommandLine(argv, argc);
}