0130 - Sort Cif

From Bitnami MediaWiki

Cerința

Se dă un vector cu n elemente numere întregi.

Să se ordoneze crescător elementele unui vector crescător după suma cifrelor.

Date de intrare

Fişierul de intrare sortcif.in conţine pe prima linie numărul n si pe a doua linie n numere întregi separate prin spaţii.

Date de ieșire

Pe ecran se va afișa mesajul: "Datele de intrare corespund restricțiilor impuse."

Pe următoarea linie se vor afișa cele n elemente ale vectorului, ordonate conform cerinței, separate printr-un spațiu.

În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, pe ecran se va afișa mesajul "Datele de intrare nu corespund restricțiilor impuse."

Restricții și precizări

  • 0 < n ≤ 100
  • valoarea absolută a numerelor de pe a doua linie a fişierului de intrare va fi mai mică decât 230.

Exemplu 1

Intrare
6
89 22 91 4005 51 721
Ieșire
Datele de intrare corespund restricțiilor impuse.
22 51 4005 91 721 89

Exemplu 2

Intrare
-2
89 22 91 4005 51 721
Ieșire
Datele de intrare nu corespund restricțiilor impuse.

Rezolvare

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

  1. 0130 Sort Cif

def conditii(n, numere):

   return len(numere) == n and \
       0 < n <= 1000 and \
       all(abs(nr) < 2**30 for nr in numere)


def sort_cif(numere):

   rezultat = sorted(numere, key=lambda numar: sum([int(cifra) for cifra in str(numar)]))
   # cheia de sortare returneaza suma cifrelor unui număr, SCif(numar) -> sum([int(cifra) for cifra in str(numar)])
   # Numerele sunt sortate după SCif(x)
   print(" ".join([str(x) for x in rezultat]))


if __name__ == "__main__":

   n = int(input())
   numere = [int(x) for x in input().split()]
   if not conditii(n, numere):
       print("Datele de intrare nu corespund restricțiilor impuse.")
   else:
       print("Datele de intrare corespund restricțiilor impuse.")
       sort_cif(numere)

</syntaxhighlight>