Pagini recente » Cod sursa (job #2858652) | Cod sursa (job #623978) | Cod sursa (job #2586216) | Cod sursa (job #1666214) | Cod sursa (job #1486360)
#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;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];
N[j] = B[i]+1;
}
j++;
}
}
for(i=1;i<n;i++) fout<<sol[i]<<"\n";
fout.close();
return 0;
}