Cod sursa(job #1510048)

Utilizator bogdan.balanBogdan Balan bogdan.balan Data 24 octombrie 2015 15:12:55
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.87 kb
//#include <fstream>
//using namespace std;
//ifstream in("lgput.in");
//ofstream out("lgput.out");
//int main()
//{
//    long long N,P,r=1;
//    in>>N>>P;
//    while(P!=1)
//        {
//        if(P%2==1){
//            r=(r*N)%1999999973;
//            P=P-1;
//        }
//        else
//        {
//            P=P/2;
//            N=(N*N)%1999999973;
//        }
//        }
//        out<<(r*N)%1999999973;
//
//    return 0;
//}


#include <fstream>

using namespace std;
ifstream in("lgput.in");
ofstream out("lgput.out");
int main()
{    int n,p,r=1,gigi;
    in>>n>>p;
    while(p!=1)
    {
        if(p%2==0)
        {
            p=p/2;
            n=(n*n)%1999999973;

        }
        else
           {

             r=(r*n)%1999999973;
             p--;
           }
    }
    gigi=(r*n)%1999999973;
    out<<gigi;
    }