1903 - V Terminal

From Bitnami MediaWiki
Revision as of 17:31, 26 November 2023 by Vasiliu Costel Andrei (talk | contribs) (Pagină nouă: == Cerința == Andrei a făcut într-o zi un șir de N numere. În a doua zi a lăsat în acel șir doar numerele prime. În a treia zi a calculat pentru fiecare număr rămas în șir suma cifrelor, iar apoi a adunat toate aceste sume în S. După ce a obținut numărul S a început să adune toate cifrele din care este format S și tot așa până când ajunge la o cifră terminală C. ;Ajutați-l pe Andrei să calculeze cifra terminală C. == Date de intrare == Fișierul...)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Cerința

Andrei a făcut într-o zi un șir de N numere. În a doua zi a lăsat în acel șir doar numerele prime. În a treia zi a calculat pentru fiecare număr rămas în șir suma cifrelor, iar apoi a adunat toate aceste sume în S. După ce a obținut numărul S a început să adune toate cifrele din care este format S și tot așa până când ajunge la o cifră terminală C.

Ajutați-l pe Andrei să calculeze cifra terminală C.

Date de intrare

Fișierul de intrare vterminal.in conține pe prima linie numărul N, iar pe a doua linie N numere naturale separate prin spații.

Date de ieșire

Fișierul de ieșire vterminal.out va conține pe prima linie numărul C, reprezentând valoarea cerută.

Restricții și precizări

  • 1 ⩽ N ⩽ 10.000
  • numerele de pe a doua linie a fișierului de intrare vor fi mai mici decât 1.000

Exemplu 1

Intrare
vterminal.in
5
4 11 24 13 97
Ieșire
vterminal.out
4


Exemplu 2

Intrare
vterminal.in
105
4 11 24 13 97
Ieșire
Eroare: Numărul N trebuie să fie între 1 și 100


Rezolvare

<syntaxhighlight lang="python" line>

  1. 1903 - V Terminal

def este_prim(numar):

   if numar < 2:
       return False
   for i in range(2, int(numar ** 0.5) + 1):
       if numar % i == 0:
           return False
   return True


def suma_cifrelor(numar):

   return sum(int(cifra) for cifra in str(numar))


def cifra_terminala(numar):

   while numar >= 10:
       numar = suma_cifrelor(numar)
   return numar


def main():

   try:
       with open("vterminal.in", "r") as fisier:
           n = int(fisier.readline().strip())
           numere = list(map(int, fisier.readline().split()))
       if not (1 <= n <= 100):
           raise ValueError("Numărul N trebuie să fie între 1 și 100")
       for numar in numere:
           if not (numar < 1000):
               raise ValueError("Numerele trebuie să fie mai mici decât 1000")
       numere_prime = [num for num in numere if este_prim(num)]
       suma_cifrelor_prime = sum(suma_cifrelor(num) for num in numere_prime)
       rezultat = cifra_terminala(suma_cifrelor_prime)
       with open("vterminal.out", "w") as fisier_out:
           fisier_out.write(str(rezultat))
   except Exception as e:
       print(f"Eroare: {str(e)}")


if __name__ == "__main__":

   main()

</syntaxhighlight>