4106 - Half Sort 4

From Bitnami MediaWiki
Revision as of 06:53, 7 November 2023 by Zmicala Narcis (talk | contribs) (Pagină nouă: == Cerinţa == Să se ordoneze crescător subșirul format din elementele negative din vector și descrescător subșirul format din elementele pozitive. Indicii subșirului format din elementele negative nu se vor schimba. La fel și indicii subșirului format din elementele pozitive. == Date de intrare == Fişierul de intrare '''halfsort4.in''' conţine pe prima linie numărul '''n''' si pe a doua linie '''n''' numere întregi nenule separate prin spaţii. == Date de ieşir...)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Cerinţa

Să se ordoneze crescător subșirul format din elementele negative din vector și descrescător subșirul format din elementele pozitive. Indicii subșirului format din elementele negative nu se vor schimba. La fel și indicii subșirului format din elementele pozitive.

Date de intrare

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

Date de ieşire

Fişierul de ieşire halfsort4.out va conţine pe prima linie cele n elemente ale vectorului, ordonate conform cerinței, separate printr-un spațiu.

Restricții și precizări

  • 0 < n ≤ 1000
  • valoarea absolută a numerelor de pe a doua linie a fişierului de intrare va fi mai mică decât 2^30

Exemplu

halfsort4.in
6
2 -1 9 -4 5 7
halfsort4.out
9 -4 7 -1 5 2

Rezolvare

<syntaxhighlight lang="python" line> def halfsort(n, arr):

   # Creăm două liste: una pentru numerele negative și una pentru cele pozitive
   neg = sorted((x for x in arr if x < 0), reverse=True)
   pos = sorted((x for x in arr if x > 0))
   # Reconstruim lista inițială. Pentru fiecare element din lista inițială:
   # - dacă este negativ, adăugăm cel mai mic număr negativ rămas (și îl eliminăm din listă)
   # - dacă este pozitiv, adăugăm cel mai mare număr pozitiv rămas (și îl eliminăm din listă)
   return [neg.pop() if x < 0 else pos.pop() for x in arr]

if __name__ == "__main__":

   # Această parte a codului va fi executată doar dacă scriptul este rulat direct
   # Testăm funcția cu datele din exemplu
   n = 6
   arr = [2, -1, 9, -4, 5, 7]
   # Afișăm rezultatul
   print(halfsort(n, arr))

</syntaxhighlight>