0946 - Doua Baze

De la Universitas MediaWiki

Cerință

Se dă un număr n scris în baza 2. Să se afișeze valoarea acestuia în baza 4.

Date de intrare

Programul citește de la tastatură scrierea în baza 2 a numărului n.

Date de ieșire

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele de intrare corespund restricțiilor impuse." și programul va afișa pe ecran scrierea în baza 4 a numărului n. În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse."

Restricții de precizări

  • n are cel mult 100 de cifre în baza 2;

Exemplu

Exemplul 1

Intrare
100011
Ieșire
Datele introduse corespund restricțiilor impuse.
203

Exemplul 2

Intrare
11010110
Ieșire
Datele introduse corespund restricțiilor impuse.
3112

Rezolvare

Rezolvare ver. 1

def validare(n):
    # Funcție care validează dacă numărul introdus este un număr binar valid
    return n.isdigit() and 0 <= len(n) <= 100


def douabaze(n):
    # Funcție care convertește un număr din baza 2 în baza 4
    # Verificăm dacă lungimea numărului n este impară și, dacă da, adăugăm un 0 la început pentru a obține o lungime pară
    while len(n) % 2 != 0:
        n = '0' + n
    # Tabela de conversie din baza 2 în baza 4
    conversion_table = {'00': '0', '01': '1', '10': '2', '11': '3'}
    # Rezultatul final în baza 4
    result = ''
    # Parcurgem numărul n în grupuri de câte 2 caractere și le convertim folosind tabela de conversie
    for i in range(0, len(n), 2):
        result += conversion_table[n[i:i + 2]]
    return result


if __name__ == '__main__':
    n = input("Introduceți un număr în baza 2: ")
    if validare(n):
        print("Datele introduse corespund restricțiilor impuse.")
        # Apelăm funcția douabaze pentru a realiza conversia
        print("Numărul în baza 4 este:", douabaze(n))
    else:
        print("Datele introduse nu corespund restricțiilor impuse.")