2586 - Get Secv Bits

De la Universitas MediaWiki
Versiunea din 6 aprilie 2023 16:48, autor: Carla Chereji (discuție | contribuții) (Pagină nouă: ==Cerință== Se dă un număr '''n''', întreg pe 32 de biți. Afișați valoarea care se obține cu biții de pe pozițiile 8, 7, 6 (în aceeași ordine ca în numărul dat). ==Date de intrare== Programul citește de la tastatură numărul '''n'''. ==Date de ieșire== Programul va afișa pe ecran numărul determinat. ==Restricții de precizări== *1 ⩽ '''n''' ⩽ 10000 ==Exemplul 1== ;Intrare :65 ;Ieșire :Datele introduse corespund restricțiilor impuse. :1 ==Ex...)
(dif) ← Versiunea anterioară | Versiunea curentă (dif) | Versiunea următoare → (dif)

Cerință

Se dă un număr n, întreg pe 32 de biți. Afișați valoarea care se obține cu biții de pe pozițiile 8, 7, 6 (în aceeași ordine ca în numărul dat).

Date de intrare

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

Date de ieșire

Programul va afișa pe ecran numărul determinat.

Restricții de precizări

  • 1 ⩽ n ⩽ 10000

Exemplul 1

Intrare
65
Ieșire
Datele introduse corespund restricțiilor impuse.
1

Exemplul 2

Intrare
157
Ieșire
Datele introduse corespund restricțiilor impuse.
5

Rezolvare ver. 1

def validare(n):
    return n.isdigit() and 1 <= int(n) <= 32


def getsecvbits(n):
    result = ( n >> 6) & 0b111  
    # folosim >> pentru a muta numărul la dreapta cu 6 poziții, pentru a muta biții,apoi aplicam operatorul de si pe biti cu valoarea 0b111


print("Valoarea obtinuta este:", result)

if __name__ == "__main__":
    n = int(input("Introduceti valoarea lui n: "))


if validare(n):
    n = int(n)

    print("Datele introduse corespund restricțiilor impuse.")
    getsecvbits(n)

else:
    print("Datele introduse nu corespund restricțiilor impuse.")