3369 - Balanced Ternary

From Bitnami MediaWiki

Cerinţa[edit | edit source]

Reprezentarea unui număr natural în baza 3 echilibrată conține cifrele 1 0 -1 și se obține scriind numărul ca sumă de puteri ale lui 3, înmulțite cu -1, 1 sau 0. Pentru a evita confuziile, cifra egală cu -1 se notează cu T, astfel că cifrele din baza 3 echilibrată sunt 1 0 T. Astfel, numărul 11 este egal cu 3^2∗(1)+3^1∗(1)+3^0∗(−1)și se reprezintă în baza 3 echilibrată 11T.Se dă un număr natural n.

Să se reprezinte numărul în baza 3 echilibrată.

Date de intrare[edit | edit source]

Programul citește de la tastatură numărul natural n.

Date de ieșire[edit | edit source]

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele sunt introduse corect.", programul va afișa pe ecran o secvență de caractere, reprezentând numărul n scris în baza 3 echilibrată. În cazul în care datele nu respectă restricțiile, se va afișa pe ecran: "Datele nu corespund restricțiilor impuse.".

Restricţii şi precizări[edit | edit source]

  • 0 ≤ n ≤ 1000000000


Exemple[edit | edit source]

Exemplul 1[edit | edit source]

Intrare
25
Ieșire
Datele sunt introduse corect.
10T1

Exemplul 2[edit | edit source]

Intrare
999999999
Ieșire
Datele nu corespund restricțiilor impuse.

Exemplul 3[edit | edit source]

Intrare
27
Ieșire
Datele sunt introduse corect.
1000



Rezolvare[edit | edit source]

<syntaxhighlight lang="python" line="1">

  1. 3369 - Balanced Ternary

def validare_numar_natural(n):

   if n < 0 or n > 1000000000:
       return False
   else:
       return True

def reprezentare_baza_3_echilibrata(n):

   reprezentare = ""
   while n != 0:
       rest = n % 3
       n //= 3
       if rest == 2:
           rest = "T"
           n += 1
       reprezentare = str(rest) + reprezentare
   if reprezentare == "":
       reprezentare = "0"
   return reprezentare

def main():

   n = int(input("Introduceți un număr natural: "))
   if validare_numar_natural(n):
       print("Datele sunt introduse corect.")
       print("Reprezentarea în baza 3 echilibrată a numărului dat este:", reprezentare_baza_3_echilibrata(n))
   else:
       print("Datele nu corespund restricțiilor impuse.")

if __name__ == "__main__":

   main()




</syntaxhighlight>

Explicatie[edit | edit source]

Funcția validare_numar_natural(n)

Această funcție verifică dacă numărul n dat ca parametru este un număr natural valid. Are un singur parametru:

n - numărul natural de verificat Funcția returnează True dacă n este un număr natural valid și False în caz contrar.

Funcția reprezentare_baza_3_echilibrata(n)

Această funcție primește un număr natural n și returnează reprezentarea în baza 3 echilibrată a acestuia. Funcția împarte repetat numărul la 3 și adaugă restul împărțirii la reprezentare, în ordine inversă. Dacă restul este 2, acesta este înlocuit cu litera "T", iar numărul este incrementat cu 1. Acest proces continuă până când numărul devine 0.

Funcția main()

Această funcție este funcția principală a programului și este rulată atunci când scriptul Python este executat. Funcția citește de la tastatură un număr natural, verifică dacă acesta este valid cu ajutorul funcției validare_numar_natural(n), calculează reprezentarea în baza 3 echilibrată a numărului dat cu ajutorul funcției reprezentare_baza_3_echilibrata(n) și afișează rezultatul la consolă. Dacă numărul dat nu corespunde restricțiilor impuse, se afișează un mesaj de eroare.