Cod sursa(job #218806)
Utilizator | Data | 3 noiembrie 2008 18:00:02 | |
---|---|---|---|
Problema | Ridicare la putere in timp logaritmic | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.36 kb |
#include<fstream.h>
#include<iostream.h>
#define kkt 1999999973
int x,n,r,i;
int main()
{ifstream in("lgput.in");
ofstream out("lgput.out");
in>>x>>n;
long long p=1;
long long m=x;
for(i=0;i<32;i++)
{if(n & (1<<i))
p=(((long long) p % kkt )* (m % kkt)) % kkt;
m=(((long long) m % kkt) * (m % kkt)) % kkt;
}
out<<p<<endl;
out.close();
return 0;
}