-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathradix.cpp
59 lines (51 loc) · 1.55 KB
/
radix.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
#include <algorithm>
#include <fstream>
#include <iostream>
#include <iterator>
#include <time.h>
using namespace std;
ifstream fin("radix.in");
ofstream fout("radix.out");
// Radix sort comparator for 32-bit two's complement integers
class radix_test {
const int bit; // bit position [0..31] to examine
public:
radix_test(int offset) : bit(offset) {} // constructor
bool operator()(int value) const // function call operator
{
if (bit == 31) // sign bit
return value < 0; // negative int to left partition
else
return !(value & (1 << bit)); // 0 bit to left partition
}
};
// Least significant digit radix sort
void lsd_radix_sort(int *first, int *last) {
for (int lsb = 0; lsb < 32; ++lsb) // least-significant-bit
{
std::stable_partition(first, last, radix_test(lsb));
}
}
// Most significant digit radix sort (recursive)
void msd_radix_sort(int *first, int *last, int msb = 31) {
if (first != last && msb >= 0) {
int *mid = std::partition(first, last, radix_test(msb));
msb--; // decrement most-significant-bit
msd_radix_sort(first, mid, msb); // sort left partition
msd_radix_sort(mid, last, msb); // sort right partition
}
}
// test radix_sort
int main() {
clock_t tStart = clock();
int data[517944];
int n = 0;
while(fin>>data[n]) {
++n;
}
lsd_radix_sort(data, data + n);
// msd_radix_sort(data, data + 8);
std::copy(data, data + n, std::ostream_iterator<int>(fout, " ")); // rrfout
printf("\n\nTimp: %.2f ms\n", (double)(clock() - tStart));
return 0;
}