Pagini recente » Cod sursa (job #35884) | Cod sursa (job #743841) | Cod sursa (job #582269) | Cod sursa (job #93384) | Cod sursa (job #3327501)
#include<bits/stdc++.h>
using namespace std;
const int MAXBITS=32;
const int BITS=8;
const int MAXN=1e7;
const int MAXM=256;
ifstream fin("radixsort.in");
ofstream fout("radixsort.out");
int v[MAXN+1];
vector<int>f[MAXM];
int main() {
int n,a,b,c;
fin>>n>>a>>b>>c;
v[0]=b;
for(int i=1; i<n; i++) {
v[i]=((long long)a*v[i-1]+b)%c;
}
int nr;
for(int j=0; j<MAXBITS/BITS; j++) {
for(int i=0; i<n; i++) {
f[(v[i]>>(j*BITS))&(MAXM-1)].push_back(v[i]);
}
nr=0;
for(auto vec:f) {
for(auto it:vec) {
v[nr++]=it;
}
vec.clear();
}
}
for(int i=0; i<n; i+=10) {
fout<<v[i]<<' ';
}
return 0;
}