Pagini: [1]   În jos
  Imprimă  
Ajutor Subiect: Ridicare la putere in O(lgN)  (Citit de 1528 ori)
0 Utilizatori şi 1 Vizitator pe acest subiect.
dornescuvlad
Nu mai tace
*****

Karma: -138
Deconectat Deconectat

Mesaje: 234



Vezi Profilul
« : Aprilie 01, 2010, 18:36:59 »

Cod:

int lgput(long long int N, long long int P)
{
if(P==0)
return 1;
if(P==1)
return N%modulo;
if(P==2)
return (N*N)%modulo;
else
{
if(P%2==0)
return (lgput(N,P/2))%modulo;
else
return (lgput(N,P/2)*N)%modulo;
}
}

Ce ar putea fi gresit la functia asta de ridicare la putere in O(lgN) ?
Multumesc
Memorat
alexandru92
Nu mai tace
*****

Karma: -191
Deconectat Deconectat

Mesaje: 496



Vezi Profilul
« Răspunde #1 : Aprilie 01, 2010, 18:44:09 »

( lgput( N, P/2 )*lgput( N, P/2 ) )%Modulo; Smile
Gandestete putin la relatia de recurenta http://en.wikipedia.org/wiki/Exponentiation_by_squaring Wink
Memorat
dornescuvlad
Nu mai tace
*****

Karma: -138
Deconectat Deconectat

Mesaje: 234



Vezi Profilul
« Răspunde #2 : Aprilie 01, 2010, 18:52:48 »

Daca as face chestia aia mi-ar calcula de doua ori
Cod:
#include<iostream>
#include<fstream>
#define modulo 1999999973

using namespace std;

ifstream fin("lgput.in");
ofstream fout("lgput.out");

long long lgput(long long int N, long long int P)
{
if(P==0)
return 1;
else
if(P%2==1)
return (N*lgput(N,(P-1)/2)*lgput(N,(P-1)/2))%modulo;
else
return (lgput(N,P/2)*lgput(N,P/2))%modulo;

}


dureaza foarte mult si mai e si incorecta pe deasupra
Memorat
alexandru92
Nu mai tace
*****

Karma: -191
Deconectat Deconectat

Mesaje: 496



Vezi Profilul
« Răspunde #3 : Aprilie 01, 2010, 19:26:35 »

Si cine te opreste sa faci asta
Cod:
long long int a=lgput( N, P/2 );
return (a*a)%Modulo

?
Memorat
dornescuvlad
Nu mai tace
*****

Karma: -138
Deconectat Deconectat

Mesaje: 234



Vezi Profilul
« Răspunde #4 : Aprilie 01, 2010, 19:30:31 »

Am facut altfel si mi-a mers Dancing
Memorat
Pagini: [1]   În sus
  Imprimă  
 
Schimbă forumul:  

Powered by SMF 1.1.19 | SMF © 2006-2013, Simple Machines