Cod sursa(job #1966247)

Utilizator nicu_serteSerte Nicu nicu_serte Data 15 aprilie 2017 01:10:32
Problema Radix Sort Scor 30
Compilator cpp Status done
Runda Arhiva educationala Marime 0.93 kb
#include <fstream>
#include <vector>
using namespace std;
ifstream fin("radixsort.in");
ofstream fout("radixsort.out");
#define nmax 10000005
int n, v[nmax], z;
void citire()
{
    int i, a, b, c;
    fin>>n>>a>>b>>c;
    fin.close();
    v[1]=b;
    for(i=2; i<=n; i++)
        v[i]=(1LL*a*v[i-1]+b)%c;
}
void afisare()
{
    int i;
    for(i=1; i<=n; i+=10)
        fout<<v[i]<<' ';
}
int key(int x)
{
    return (x/z)%10;
}
void sortare()
{
    int i, k;
    vector<int> bucket[10];
    vector<int>::iterator it;
    for(i=1; i<=n; i++)
        bucket[key(v[i])].push_back(v[i]);
    k=0;
    for(i=0; i<=9; i++)
    {
        for(it=bucket[i].begin(); it!=bucket[i].end(); it++)
            v[++k]=*it;
    }
}
void radix()
{
    int i;
    z=1;
    for(i=1; i<=10; i++)
    {
        sortare();
        z=z*10;
    }
}
int main()
{
    citire();
    radix();
    afisare();
    return 0;
}