Cod sursa(job #1625097)

Utilizator marioviperconstantin mario marioviper Data 2 martie 2016 16:41:39
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.57 kb
#include <fstream>
#define  m 1999999973
using namespace std;

ifstream f("lgput.in");
ofstream g("lgput.out");
int putere ( int a , int b)
{   if(b==0)
    return 1;
    if(b==1)
    return a ;
     if (b%2 ==0 )
     return ((putere(a , b/2)%m)* (putere(a,b/2)%m))%m;
     if(b%2 ==1)
     return ((putere(a,b/2)%m)* (putere(a,b/2)%m)* putere(a,1))%m;

      }

int putere2 ( int a , int b)
{ int c = a ;
    for(int i =2; i<=b ;i++)
        c=c*a;
    return c ;
}

int main()
{
    int a ,b ;
    f>>a>>b;
    g<<putere(a,b);

    return 0;
}