Informatică, întrebare adresată de pmarian98, 8 ani în urmă

#2326 Campionat

Cerința
La un campionat de șah participa n persoane. Știind că la fiecare rundă se fac grupe de câte 2 persoane, iar câștigătorul trece în runda următoare, aflați după câte runde se va află câștigătorul.

Date de intrare
Programul citește de la tastatură numărul n.

Date de ieșire
Programul va afișa pe ecran numărul de runde.

Restricții și precizări
n ≤ 4.444.444.444
Dacă nu se poate realiza campionatul în conformitate cu regulile de mai sus, se va afișa -1.
Exemplul 1:
Intrare

4
Ieșire

2
Explicație
În prima rundă se formează 2 grupe de 2 participanți. În runda următoare va fi o grupa de 2, după care se va află câștigătorul.

Exemplul 2:
Intrare

3
Ieșire

-1
Explicație
Nu se poate realiza campionatul cu regulile din enunț.


ProMinecraft69: Obtin 80 de puncte, imediat ce gasesc lipsa iti dau codul.
boiustef: 80
ProMinecraft69: 90 :)))
boiustef: pune long long ... :)))
ProMinecraft69: Nu era de long long :))

Răspunsuri la întrebare

Răspuns de boiustef
2

Răspuns:

Explicație:

#include <iostream>

#include <cmath>

using namespace std;

long long n;

int main()

{

   cin >> n;

   if (log2(n)==(int)log2(n))

   {

       cout << (int)log2(n);

   }

   else cout << -1;

}

Răspuns de ProMinecraft69
3

Răspuns:

Explicație:

#include <iostream>

using namespace std;

int main()

{

   long long int sahisti, runde = 0 ;

   cin >> sahisti;

   if(sahisti &(sahisti -1))

       cout <<-1;

   else

   {

       while(sahisti % 2 == 0)

       {

           sahisti = sahisti / 2;

           runde++;

       }

       if(sahisti == 1)

       cout << runde;

       else cout << -1;

   }

   return 0;

}


ProMinecraft69: Operatul & inseamna si, dar pe biti. Prin sahisti & sahisti -1 am verificat daca numarul este putere a lui 2, daca nu este afisez -1 altfel calculez rundele.
boiustef: eu am folosit puţină matematică...
boiustef: eu din start am luat int n, deaceea luam 80
Alte întrebări interesante