Pagini recente » Cod sursa (job #2705674) | Cod sursa (job #1614276) | Cod sursa (job #2545202) | Cod sursa (job #319661) | Cod sursa (job #3265462)
#include <iostream>
#include <fstream>
void countingSort (int arr[], int n, int exp){
int output[n];
int i, count[10] = { 0 };
for (i = 0; i < n; i++)
count[(arr[i] / exp) % 10]++;
for (i = 1; i < 10; i++)
count[i] += count[i - 1];
for (i = n - 1; i >= 0; i--) {
output[count[(arr[i] / exp) % 10] - 1] = arr[i];
count[(arr[i] / exp) % 10]--;
}
for (i = 0; i < n; i++)
arr[i] = output[i];
}
void radixSort(int arr[], int n){
int max;
for (int i = 0; i < n; i++){
if(arr[i] > max){
max = arr[i];
}
}
for (int i = 1; max / i > 0; i *= 10)
countingSort(arr, n, i);
}
int main(){
std::ifstream input ("radixsort.in");
std::ofstream output ("radixsort.out");
int a,b,c, n;
input >> n >> a >> b >>c;
int arr[n];
arr[0] = b;
for(int i = 1; i < n; i ++){
arr[i] = (a * arr[i-1] + b) % c;
}
radixSort(arr, n);
for (int i = 0; i < n; i++){
output << arr[i] << ' ';
}
return 0;
}