Cod sursa(job #268337)
Utilizator | Data | 1 martie 2009 08:26:15 | |
---|---|---|---|
Problema | 12-Perm | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.47 kb |
#include<iostream.h>
#include<stdio.h>
#define c 1048576
FILE *f=fopen("12perm.in","r"),*g=fopen("12perm.out","w");
int main()
{//a mod 2^k <-> a & ((2^k)-1)
int x[]={0,1,2,6,12},i,n;
fscanf(f,"%d",&n);
if(n<=4)
{
fprintf(g,"%d\n",x[n]);
}
else
{
for(i=5;i<=n;i++)
{
x[4]=(x[4]+x[2]+2*(i-2))&(c-1);
x[2]=x[3];x[3]=x[4];
}
fprintf(g,"%d\n",x[4]);
}
return 0;
}