0383 - inlocuireK: Difference between revisions

From Bitnami MediaWiki
Anularea modificării 2014 făcute de Csatari Mălina (Discuție)
Tag: Undo
Line 82: Line 82:
== Explicație rezolvare==
== Explicație rezolvare==
   Funcția '''citire_conform_restrictiilor''' verifică dacă datele de intrare respectă restricțiile impuse în enunțul problemei și returnează valorile k, n și vectorul de numere în cazul în care sunt valide. În caz contrar, afișează un mesaj de eroare și oprește programul prin apelul funcției exit().<br>  
   Funcția '''citire_conform_restrictiilor''' verifică dacă datele de intrare respectă restricțiile impuse în enunțul problemei și returnează valorile k, n și vectorul de numere în cazul în care sunt valide. În caz contrar, afișează un mesaj de eroare și oprește programul prin apelul funcției exit().<br>  
   Funcția '''inloc_elem_cu_multiplu_k_cel_mai_apropiat''' primește vectorul și numărul de elemente n din vector, precum și numărul natural k și efectuează următoarele operații:<br>->pentru fiecare element din vector, găsește cel mai apropiat multiplu al lui k, prin împărțirea elementului la k și înmulțirea rezultatului cu k;<br>-> determină dacă cel mai apropiat multiplu este a sau b, unde b este multiplul lui k imediat mai mare decât a;<br>-> înlocuiește elementul din vector cu cel mai apropiat multiplu găsit;<br>-> afișează elementele vectorului, după înlocuire, în ordine inversă.<br>  
   Funcția '''inloc_elem_cu_multiplu_k_cel_mai_apropiat''' primește vectorul și numărul de elemente n din vector, precum și numărul natural k și efectuează următoarele operații:<br>-> pentru fiecare element din vector, găsește cel mai apropiat multiplu al lui k, prin împărțirea elementului la k și înmulțirea rezultatului cu k;<br>-> determină dacă cel mai apropiat multiplu este a sau b, unde b este multiplul lui k imediat mai mare decât a;<br>-> înlocuiește elementul din vector cu cel mai apropiat multiplu găsit;<br>-> afișează elementele vectorului, după înlocuire, în ordine inversă.<br>  
   La final, programul citește datele de intrare, apelează funcția '''inloc_elem_cu_multiplu_k_cel_mai_apropiat''' și afișează vectorul obținut în ordine inversă.
   La final, programul citește datele de intrare, apelează funcția '''inloc_elem_cu_multiplu_k_cel_mai_apropiat''' și afișează vectorul obținut în ordine inversă.

Revision as of 13:01, 31 March 2023

Sursa: 0383- inlocuireK


Cerinţa

Se dă un număr natural nenul k și vector cu n numere naturale. Să se înlocuiască fiecare element cu multiplul lui k cel mai apropiat de el și să se afișeze elementele astfel obținute în ordine inversă.

Date de intrare

Programul citește de la tastatură numerele k și n, iar apoi n numere naturale, separate prin spaţii, reprezentând elementele vectorului.

Date de ieșire

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele sunt introduse corect.", apoi pe un rând nou va afișa elementele vectorului, după înlocuire, în ordine inversă, separate prin exact un spațiu. Î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

  • 1n200
  • 1k100
  • elementele vectorului vor fi cuprinse între 1 și 1.000.000
  • dacă pentru un element al vectorului există mai multi cei mai apropiați multipli ai lui k, elementul va fi înlocui cu cel mai mic dintre aceștia

Exemple

Exemplul 1

Intrare
5 4
17 14 24 25
Ieșire
Datele sunt introduse corect.
25 25 15 15

Exemplul 2

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


Rezolvare

<syntaxhighlight lang="python" line>

  1. 0383

def inloc_elem_cu_multiplu_k_cel_mai_apropiat(vector, n, k):

   for i in range(n):
       a = vector[i] // k * k
       b = a + k
       if abs(vector[i] - a) <= abs(b - vector[i]):
           vector[i] = a
       else:
           vector[i] = b
   for i in range(n-1, -1, -1):
       print(vector[i], end=' ')


def citire_conform_restrictiilor():

   k, n = map(int, input().split())
   if n < 1 or n > 200 or k < 1 or k > 100:
       print("Datele nu corespund restricțiilor impuse.")
       exit()
   vector = list(map(int, input().split()))
   for x in vector:
       if x < 1 or x > 1000000:
           print("Datele nu corespund restricțiilor impuse.")
           exit()
   if n != len(vector):
       print("Datele nu corespund restricțiilor impuse.")
       exit()
   print("Datele sunt introduse corect.")
   return k, n, vector


if __name__ == '__main__':

   k, n, vector = citire_conform_restrictiilor()
   inloc_elem_cu_multiplu_k_cel_mai_apropiat(vector, n, k)







</syntaxhighlight>

Explicație rezolvare

  Funcția citire_conform_restrictiilor verifică dacă datele de intrare respectă restricțiile impuse în enunțul problemei și returnează valorile k, n și vectorul de numere în cazul în care sunt valide. În caz contrar, afișează un mesaj de eroare și oprește programul prin apelul funcției exit().
Funcția inloc_elem_cu_multiplu_k_cel_mai_apropiat primește vectorul și numărul de elemente n din vector, precum și numărul natural k și efectuează următoarele operații:
-> pentru fiecare element din vector, găsește cel mai apropiat multiplu al lui k, prin împărțirea elementului la k și înmulțirea rezultatului cu k;
-> determină dacă cel mai apropiat multiplu este a sau b, unde b este multiplul lui k imediat mai mare decât a;
-> înlocuiește elementul din vector cu cel mai apropiat multiplu găsit;
-> afișează elementele vectorului, după înlocuire, în ordine inversă.
La final, programul citește datele de intrare, apelează funcția inloc_elem_cu_multiplu_k_cel_mai_apropiat și afișează vectorul obținut în ordine inversă.