2586 - Get Secv Bits: Difference between revisions
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... |
Vardai Erwin (talk | contribs) |
||
Line 27: | Line 27: | ||
:Datele introduse corespund restricțiilor impuse. | :Datele introduse corespund restricțiilor impuse. | ||
: | :2 | ||
== Rezolvare ver. 1 == | == Rezolvare ver. 1 == |
Revision as of 16:00, 22 April 2023
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.
- 2
Rezolvare ver. 1
<syntaxhighlight lang="python" line="1" start="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.")
</syntaxhighlight>