#include <algorithm>
const int ful = (1 << 16) - 1;
int tt[ful + 5];
void sort(unsigned *a, int n) {
unsigned *tmp = new unsigned[n];
for (register int i = 0; i < n; i++) ++tt[a[i] & ful];
for (register int i = 1; i <= ful; i++) tt[i] += tt[i - 1];
for (register int i = n - 1; ~i; i--) tmp[--tt[a[i] & ful]] = a[i];
std::swap(a, tmp);
for (register int i = 0; i <= ful; i++) tt[i] = 0;
for (register int i = 0; i < n; i++) ++tt[(a[i] >> 16) & ful];
for (register int i = 1; i <= ful; i++) tt[i] += tt[i - 1];
for (register int i = n - 1; ~i; i--) tmp[--tt[(a[i] >> 16) & ful]] = a[i];
std::swap(a, tmp);
}