Pagini recente » Cod sursa (job #1402166) | Cod sursa (job #2065709) | Cod sursa (job #2035169) | Cod sursa (job #1672858) | Cod sursa (job #1486354)
#include <fstream>
#define Nmax 1000005
using namespace std;
ifstream fin("curcubeu.in");
ofstream fout("curcubeu.out");
int n,sol[Nmax];
int A[Nmax],B[Nmax],C[Nmax],N[Nmax];
int main()
{
int i,a,b,c,j;
fin>>n>>a>>b>>c;
if(a>b) swap(a,b);
A[1] = a; B[1] = b; C[1] = c;
for(i=2;i<n;i++)
{
a = (1LL*a*i)%n;
b = (1LL*b*i)%n;
c = (1LL*c*i)%n;
if(a>b) swap(a,b);
A[i] = a; B[i] = b; C[i] = c;
}
for(i=n-1;i>=1;i--)
{
j = A[i];
while(j<=B[i])
{
if(N[j]!=0) while(N[j]!=0) j = N[j];
else sol[j] = C[i];
j++;
}
N[A[i]] = B[i];
}
for(i=1;i<n;i++) fout<<sol[i]<<"\n";
fout.close();
return 0;
}