Pagini recente » Cod sursa (job #1966140) | Cod sursa (job #2959790) | Cod sursa (job #199889) | Cod sursa (job #37582) | Cod sursa (job #1644325)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("rsir.in");
ofstream fout("rsir.out");
int rez[7010];
int main()
{
int t0, t1, a, b, x, y, z, m, ix, iy, i, iz, ix2, iy2, iz2;
long long n;
int cn = n;
fin >> t0 >> t1 >> a >> b >> x >> y >> z >> m >> n;
t0 %= m;
t1 %= m;
ix = t0;
ix2 = (ix * ix) % m;
iy = t1;
iy2 = (iy * iy) % m;
for(i = 2 ; ; i++)
{
// cout << ix << " " << iy << "\n";
iz = (a * ix2 + b * iy2 + x * ix + y * iy + z) % m;
iz2 = (iz * iz) % m;
ix = iy;
ix2 = iy2;
iy = iz;
iy2 = iz2;
if(ix == t0 && iy == t1)
break;
}
i--;
n %= i;
cn = (int)n;
if(cn == 0)
{
fout << t0 << "\n";
}
else if(cn == 1)
{
fout << t1 << '\n';
}
else
{
ix = t0;
ix2 = (ix * ix) % m;
iy = t1;
iy2 = (iy * iy) % m;
for(i = 2 ; i <= cn ; i++)
{
iz = (a * ix2 + b * iy2 + x * ix + y * iy + z) % m;
iz2 = (iz * iz) % m;
ix = iy;
ix2 = iy2;
iy = iz;
iy2 = iz2;
}
cout << iz << "\n";
}
}