Cod sursa(job #615212)
| Utilizator | Data | 8 octombrie 2011 21:47:35 | |
|---|---|---|---|
| Problema | Ridicare la putere in timp logaritmic | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.38 kb |
#include <fstream>
#include <cstdlib>
#define MODULO 1999999973
using namespace std;
inline int power( int x, int n )
{
int r;
for( r=1; n; n>>=1 )
{
if( n&1 )
{
r=(1LL*r*x)%MODULO;
--n;
}
x=(1LL*x*x)%MODULO;
}
return r;
}
int main( void )
{
int x, n;
ifstream in( "lgput.in" );
in>>x>>n;
ofstream out( "lgput.out" );
out<<power( x, n )<<'\n';
return EXIT_SUCCESS;
}
