Cod sursa(job #257351)

Utilizator GodiesVlad Voicu Godies Data 13 februarie 2009 04:22:40
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator c Status done
Runda Arhiva educationala Marime 0.53 kb
#include<stdio.h>
#include<stdlib.h>

long put(long a, long b)
{
    long result=1;
    while(b)
    {
        if(b%2==1)
        {
            result=(result*a)%1999999973;
            b=b-1;
        }
        else
        {
            a=(a*a)%1999999973;
            b=b/2;
        }
    }
    return result;

}

int main()
{
    int a, b;
    FILE *f=fopen("lgput.in" , "rt");
    FILE *g=fopen("lgput.out" , "wt");
    fscanf(f , "%d%d" , &a,  &b);
    fprintf(g, "%d" , ((put(a, b))));
    return 0;

}