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) |
||
(2 intermediate revisions by the same user not shown) | |||
Line 5: | Line 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 | ||
Line 27: | Line 28: | ||
:Datele introduse corespund restricțiilor impuse. | :Datele introduse corespund restricțiilor impuse. | ||
: | :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) <= | 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) | |||
if __name__ == "__main__": | if __name__ == "__main__": | ||
n = | n = input("Introduceti valoarea lui n: ") | ||
if validare(n): | |||
n = int(n) | |||
if validare(n): | print("Datele introduse corespund restricțiilor impuse.") | ||
getsecvbits(n) | |||
else: | |||
print("Datele introduse nu corespund restricțiilor impuse.") | |||
else: | |||
</syntaxhighlight> | </syntaxhighlight> |
Latest revision as of 19:23, 24 April 2023
Cerință[edit | edit source]
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[edit | edit source]
Programul citește de la tastatură numărul n.
Date de ieșire[edit | edit source]
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[edit | edit source]
- 1 ⩽ n ⩽ 10000
Exemplul 1[edit | edit source]
- Intrare
- 65
- Ieșire
- Datele introduse corespund restricțiilor impuse.
- 1
Exemplul 2[edit | edit source]
- Intrare
- 157
- Ieșire
- Datele introduse corespund restricțiilor impuse.
- 2
Rezolvare ver. 1[edit | edit source]
<syntaxhighlight lang="python" line="1" start="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.")
</syntaxhighlight>