Pagini recente » Cod sursa (job #3127236) | Cod sursa (job #2165298) | Cod sursa (job #768572) | Cod sursa (job #2462872) | Cod sursa (job #1800488)
#include <iostream>
#include <cstdio>
#include <queue>
using namespace std;
queue <int> corn[10];
int n;
int v[10000100];
FILE *g=fopen("radixsort.out","w");
void afish()
{
for(int i=1; i<=n; i+=10)
fprintf(g,"%d ",v[i]);
}
int main()
{
int a,b,c;
int ok=false;
FILE *f=fopen("radixsort.in","r");
fscanf(f,"%d%d%d%d",&n,&a,&b,&c);
v[1]=b;
for(int i=2; i<=n; i++)
{
v[i] = (a*v[i-1] + b) % c;
}
long long divv=1;
int step;
for(step=1; step<=10; step++)
{
//cout<<step<<"\n";
for(int i=1; i<=n; i++)
corn[(v[i]/divv)%10].push(v[i]);
int k=0;
for(int i=0; i<=9; i++)
{
while(!corn[i].empty())
{
v[++k]=corn[i].front();
corn[i].pop();
}
}
divv=divv*10;
}
afish();
return 0;
}