2586 - Get Secv Bits: Diferență între versiuni

De la Universitas MediaWiki
(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...)
 
 
(Nu s-au afișat 2 versiuni intermediare efectuate de același utilizator)
Linia 5: Linia 5:
Programul citește de la tastatură numărul '''n'''.
Programul citește de la tastatură numărul '''n'''.
==Date de ieșire==
==Date de ieșire==
Programul va afișa pe ecran numărul determinat.
Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele de intrare corespund restricțiilor impuse." Programul va afișa pe ecran numărul determinat. În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse."
 
==Restricții de precizări==
==Restricții de precizări==
*1 ⩽ '''n''' ⩽ 10000
*1 ⩽ '''n''' ⩽ 10000
Linia 27: Linia 28:
:Datele introduse corespund restricțiilor impuse.
:Datele introduse corespund restricțiilor impuse.


:5
:2


== Rezolvare ver. 1 ==
== Rezolvare ver. 1 ==
<syntaxhighlight lang="python" line="1" start="1">
<syntaxhighlight lang="python" line="1" start="1">
def validare(n):
def validare(n):
     return n.isdigit() and 1 <= int(n) <= 32
     return n.isdigit() and 1 <= int(n) <= 10000




def getsecvbits(n):
def getsecvbits(n):
     result = ( n >> 6) & 0b111
     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
     # 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)


print("Valoarea obtinuta este:", result)


if __name__ == "__main__":
if __name__ == "__main__":
     n = int(input("Introduceti valoarea lui n: "))
     n = input("Introduceti valoarea lui n: ")
 
    if validare(n):
 
        n = int(n)
if validare(n):
        print("Datele introduse corespund restricțiilor impuse.")
    n = int(n)
        getsecvbits(n)
 
    else:
    print("Datele introduse corespund restricțiilor impuse.")
        print("Datele introduse nu corespund restricțiilor impuse.")
    getsecvbits(n)
 
else:
    print("Datele introduse nu corespund restricțiilor impuse.")


</syntaxhighlight>
</syntaxhighlight>

Versiunea curentă din 24 aprilie 2023 19:23

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

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele de intrare corespund restricțiilor impuse." Programul va afișa pe ecran numărul determinat. În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse."

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.
2

Rezolvare ver. 1

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


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 = 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.")