2896 - binar1

From Bitnami MediaWiki

Pentru a converti un număr din zecimal în binar îl vom împărți la 2 în mod repetat, până ce obținem câtul zero. Apoi vom colecta resturile obținute de la ultimul către primul. Aceste resturi sunt cifrele din reprezentarea binară a numărului dat, de la stânga la dreapta. De exemplu, 13(10) = 1101(2).

Cerința

Scrieți un program care, pentru un șir dat de n numere naturale, rezolvă următoarele cerințe:

1) Determină cel mai mare dintre cele n numere date ce are număr maxim de valori de 1 în reprezentarea binară.

2) Determină cea mai lungă secvență de numere care au număr egal de valori de 1 în reprezentarea binară. Dacă sunt mai multe astfel de secvențe de lungime maximă, se va alege cea mai din stânga. O secvență este un subșir de numere care apar pe poziții consecutive în șirul inițial.

Date de intrare

Fișierul de intrare input.txt conţine pe prima linie numărul C reprezentând cerința (1 sau 2), pe a doua linie numărul natural n, iar pe a treia linie n numere naturale separate prin câte un spațiu.

Date de ieșire

Dacă C = 1, atunci pe prima linie a fișierului de ieșire output.txt se va scrie numărul ce reprezintă răspunsul la cerința 1. Dacă C = 2, atunci pe prima linie a fișierului de ieșire output.txt se vor scrie, separate printr-un spațiu, lungimea maximă a secvenței determinate și poziția primului termen din secvență (se consideră că primul număr din cele n numere date se găsește pe poziția 1).

Restricții și precizări

  • 1 ≤ n ≤ 1.000.000

Exemplul 1

input.txt:

1

7

16 12 3 5 14 13 11

output.txt:

14

Explicație:

16(10) = 10000(2); 12(10) = 1100(2); 3(10) = 11(2); 5(10) = 101(2); 14(10) = 1110(2); 13(10) = 1101(2); 11(10) = 1011(2);

Cel mai mare număr de valori de 1 dintr-o reprezentare binară este 3; cel mai mare număr ce are 3 de 1 în reprezentarea binară este 14.

Exemplul 2

input.txt:

2

7

16 12 3 5 14 13 11

output.txt:

3 2

Explicație:

Sunt două secvențe de lungime maximă de numere care au număr egal de valori de 1 în reprezentarea binară: 12 3 5 și 14 13 11. O vom alege pe cea mai din stânga, care are lungimea 3 și începe la poziția 2.

Exemplul 3

input.txt:

2

99999999999999

16 12 3 5 14 13 11

Output:

Input-ul nu convine conditiilor

Rezolvare

<syntaxhighlight lang="python3" line="1"> NM = 1000001

def verificare(n):

   if not(1<=n<=1000000):
       print("Input-ul nu convine conditiilor")
       exit()

def count_set_bits(num):

   count = 0
   while num:
       count += num & 1
       num >>= 1
   return count

with open("input.txt", "r") as fin, open("output.txt", "w") as fout:

   c = int(fin.readline())
   n = int(fin.readline())
   verificare(n)
   l=list(map(int, fin.readline().split()))
   a = [0] * (n + 1)
   
   xmax = 0
   nr1max = 0
   
   for i in range(1, n + 1):
       x = l[i-1]
       aux = x
       nr1 = 0
       
       while aux > 0:
           nr1 += 1
           aux = aux & (aux - 1)
       
       if nr1 > nr1max or (nr1 == nr1max and x > xmax):
           nr1max = nr1
           xmax = x
       
       a[i] = nr1
   
   if c == 1:
       # cerinta 1
       fout.write(str(xmax))
   else:
       # cerinta 2
       lgm = 0
       lgc = 1
       pc = 1
       
       for i in range(2, n + 1):
           if a[i] == a[i - 1]:
               lgc += 1
           else:
               if lgc > lgm:
                   lgm = lgc
                   pm = pc
               lgc = 1
               pc = i
       
       if lgc > lgm:
           lgm = lgc
           pm = pc
       
       fout.write(f"{lgm} {pm}")

</syntaxhighlight>