3156 - perm min max

From Bitnami MediaWiki
Revision as of 18:31, 2 June 2024 by Benzar Ioan (talk | contribs) (Pagină nouă: == Cerința == Să se genereze toate permutările posibile ale unui șir de numere naturale, cu restricția ca permutarea să conțină numărul minim și numărul maxim din șir în poziții consecutive. == Date de intrare == Programul citește de la tastatură un șir de n numere naturale. == Date de ieșire == Pe ecran se vor afișa toate permutările șirului care respectă restricția dată, câte una pe linie. == Restricții și precizări == *1 ⩽ '''n''' ⩽ 10 *...)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Cerința

Să se genereze toate permutările posibile ale unui șir de numere naturale, cu restricția ca permutarea să conțină numărul minim și numărul maxim din șir în poziții consecutive.

Date de intrare

Programul citește de la tastatură un șir de n numere naturale.

Date de ieșire

Pe ecran se vor afișa toate permutările șirului care respectă restricția dată, câte una pe linie.

Restricții și precizări

  • 1 ⩽ n ⩽ 10
  • 'x' Numerele din șir sunt naturale și distincte

Exemplu 1

Intrare

3 1 2

Iesire

1 3 2
2 3 1
3 1 2
3 2 1


Rezolvare

<syntaxhighlight lang="python" line> from itertools import permutations

def citeste_date():

   try:
       sir = list(map(int, input("Introduceți șirul de numere naturale, separate prin spațiu: ").split()))
       return sir
   except ValueError:
       return None

def valideaza_date(sir):

   if not (1 <= len(sir) <= 10):
       return False
   if not all(isinstance(num, int) and num >= 0 for num in sir):
       return False
   if len(sir) != len(set(sir)):
       return False
   return True

def permutari_cu_min_max(sir):

   min_val = min(sir)
   max_val = max(sir)
   permutari = permutations(sir)
   permutari_valide = []
   
   for perm in permutari:
       for i in range(len(perm) - 1):
           if (perm[i] == min_val and perm[i + 1] == max_val) or (perm[i] == max_val and perm[i + 1] == min_val):
               permutari_valide.append(perm)
               break
   
   return permutari_valide

def main():

   sir = citeste_date()
   
   if sir is None or not valideaza_date(sir):
       print("Datele de intrare nu corespund restricțiilor impuse.")
       return
   
   print("Datele de intrare corespund restricțiilor impuse.")
   permutari = permutari_cu_min_max(sir)
   
   for perm in permutari:
       print(" ".join(map(str, perm)))

if __name__ == "__main__":

   main()

</syntaxhighlight>