Cod sursa(job #3293571)

Utilizator tudorhTudor Horobeanu tudorh Data 12 aprilie 2025 00:10:40
Problema Radix Sort Scor 30
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.85 kb
#include <bits/stdc++.h>

using namespace std;
ifstream fin("radixsort.in");
ofstream fout("radixsort.out");
int v[10000000];
int temp[10000000];
int main()
{
    int n,A,B,C;
    long long mx;
    fin>>n>>A>>B>>C;
    v[0]=B;
    mx=v[0];
    for(int i=1;i<n;i++)
    {
        v[i]=(1ll*A*v[i-1]+B)%C;
        mx=max(mx,1ll*v[i]);
    }
    int mx2=mx;
    while(mx/10)
        mx/=10;
    while(mx<=mx2)
    {
        int freq[10]={0};
        for(int i=0;i<n;i++)
            freq[v[i]/mx%10]++;
        for(int i=1;i<10;i++)
            freq[i]+=freq[i-1];
        for(int i=n-1;i>=0;i--)
        {
            freq[v[i]/mx%10]--;
            temp[freq[v[i]/mx%10]]=v[i];
        }
        for(int i=0;i<n;i++)
            v[i]=temp[i];
        mx*=10;
    }
    for(int i=0;i<n;i+=10)
        fout<<v[i]<<' ';
    return 0;
}