Cod sursa(job #436154)

Utilizator alexandru92alexandru alexandru92 Data 8 aprilie 2010 08:26:21
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.58 kb
/* 
 * File:   main.cpp
 * Author: VirtualDemon
 *
 * Created on April 8, 2010, 8:23 AM
 */
#include <cstdlib>
#include <fstream>
#define Modulo 1999999973

/*
 * 
 */
using namespace std;
inline int pow( int x, int n ) // x^n
{
    int r=1;
    for( ; n; n>>=1 )
    {
        if( n&1 )
        {
            r=(1LL*r*x)%Modulo;
            --n;
        }
        x=(1LL*x*x)%Modulo;
    }
    return r;
}
int main(int argc, char** argv)
{
    int N, x;
    ifstream in( "lgput.in" );
    in>>x>>N;
    ofstream out( "lgput.out" );
    out<<pow( x, N )<<'\n';
    return EXIT_SUCCESS;
}