2581 - Set Bit 1

De la Universitas MediaWiki

Cerință

Se dau: n un număr întreg și b un număr natural. Setați la 1 bitul b al lui n.

Date de intrare

Programul citește de la tastatură numărul n și numărul b. Valoarea citită pentru n se presupune că se stochează într-o variabilă memorată pe 64 de biți cu semn.

Date de ieșire

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele de intrare corespund restricțiilor impuse." Afișează valoarea variabilei după setarea valorii bitului conform cerinței. În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse."

Restricții de precizări

  • 0 ⩽ b ⩽ 63
  • valorile celorlalți biți rămân nemodificate
  • prima valoare citită se poate memora pe 64 de biți cu semn

Exemplul 1

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

Exemplul 2

Intrare
10 2
Ieșire
Datele introduse corespund restricțiilor impuse.
14

Rezolvare ver. 1

def validare(n, b):
    return b.isdigit() and 0 <= int(b) <= 63

def setbit(n, b): # setăm la 0 bitul b al lui n
    mask = 1 << b  # construim masca
    n = n | mask  # aplicăm masca pe n
    print(f"Numărul actualizat este: {n}")


if __name__ == "__main__":
    n = input("Introduceți numărul n: ")  # citim n de la tastatură
    b = input("Introduceți poziția bitului care trebuie setat la 1: ")  # citim bitul de la tastatură

    if validare(n, b):
        n = int(n)
        b = int(b)
        print("Datele introduse corespund restricțiilor impuse.")
        setbit(n, b)
    else:
        print("Datele introduse nu corespund restricțiilor impuse.")