1452 Stergere Element: Difference between revisions

From Bitnami MediaWiki
Pagină nouă: Sursa: [https://www.pbinfo.ro/probleme/1452/stergere-element - Stergere_Element] ---- == Cerinţa == Se dă un șir cu '''n''' elemente întregi și un număr '''p'''. Să se șteargă din șirul '''X''' elementul aflat pe poziția p. == Date de intrare == Programul va citi de la tastatură două valori '''n p''', cu semnificația precizată, apoi '''n''' numere întregi reprezentând elementele șirului. == Date de ieșire == Dacă datele sunt introduse corect, pe ecran se...
 
mNo edit summary
 
(2 intermediate revisions by the same user not shown)
Line 39: Line 39:




def citire_conform_restrictiilor():
def citire_conform_restrictiilor(n, p, X):
    n, p = map(int, input().split())
     if n < 1 or n > 1500 or p < 1 or p > 1500 or p > n:
     if n < 1 or n > 1500 or p < 1 or p > 1500 or p > n:
         print("Datele nu corespund restricțiilor impuse.")
         print("Datele nu corespund restricțiilor impuse.")
         exit()
         exit()
     X = list(map(int, input().split()))
     if n != len(X):
     for c in X:
        print("Datele nu corespund restricțiilor impuse.")
         if c >= 1000000 or c <= -1000000:
        exit()
     for element in X:
         if element >= 1000000 or element <= -1000000:
             print("Datele nu corespund restricțiilor impuse.")
             print("Datele nu corespund restricțiilor impuse.")
             exit()
             exit()
     print("Datele sunt introduse corect.")
     print("Datele sunt introduse corect.")
    return X, n, p




if __name__ == '__main__':
if __name__ == '__main__':
     X, n, p = citire_conform_restrictiilor()
     n, p = map(int, input().split())
    X = list(map(int, input().split()))
    citire_conform_restrictiilor(n, p, X)
     stergere_element(X, n, p)
     stergere_element(X, n, p)




Line 62: Line 65:


</syntaxhighlight>
</syntaxhighlight>
== Explicație rezolvare ==
    Programul de mai sus conține două funcții, funcția '''stergere_element(X, n, p)''' și funcția '''citire_conform_restrictiilor(n, p, X)''', care se vor rula în interiorul main-ului ('''if __name__ == '__main__' ''', linia 25) după citirea numerelor n, p (linia 26) și cele n numere pe care le vom pune în șirul „X” (linia 27).<br>  După ce am citit elementele, se va apela funcția '''citire_conform_restrictiilor(n, p, X)''' care primește trei parametri: n, p, X. Funcția verifică mai întâi dacă n este între 1 și 1500 și dacă p este mai mic decât 1500 și este mai mare decât n (linia 12), dacă n este lungimea vectorului X (linia 15) și dacă elementele vectorului sunt cuprinse între -1.000.000 și 1.000.000 (liniile 18, 19). Dacă oricare dintre condiții este încălcată, se va afișa mesajul „Datele nu corespund restricțiilor impuse.” și se va ieși din program cu comanda exit(). Dacă toate condițiile sunt respectate, se va afișa mesajul „Datele sunt introduse corect.” (linia 22) și se va continua programul.<br>  Dacă s-au introdus corect datele, se va apela funcția '''stergere_element(X, n, p)''' care primește ca parametrii vectorul X și numerele n, p. Această funcție începe cu un for care începe de pe poziția p-1 (deoarece vectorul nostru începe de pe poziția 0) și mută toate elementele cu o poziție înainte (liniile 4, 5). Apoi, se decrementează cu unul 1 numărul n, deoarece se scoate un element din vector, așadar lungimea sa va scădea cu 1. În final, afișăm elementele din vectorul X cu un for care ia elementele de la 1 la noul n (liniile 7, 8), separate cu un spațiu.

Latest revision as of 19:22, 8 April 2023

Sursa: - Stergere_Element


Cerinţa[edit | edit source]

Se dă un șir cu n elemente întregi și un număr p. Să se șteargă din șirul X elementul aflat pe poziția p.

Date de intrare[edit | edit source]

Programul va citi de la tastatură două valori n p, cu semnificația precizată, apoi n numere întregi reprezentând elementele șirului.

Date de ieșire[edit | edit source]

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele sunt introduse corect.", apoi pe un rând nou va afișa pe ecran n-1 valori întregi, separate printr-un spațiu, reprezentând elementele șirului după ștergere. În cazul contrar, se va afișa pe ecran: "Datele nu corespund restricțiilor impuse.".

Restricţii şi precizări[edit | edit source]

  • 1 ⩽ pn ⩽ 1.000
  • valoarea X și elementele șirului vor fi cuprinse între -1.000.000 și 1.000.000
  • elementele șirului vor avea indici între 1 și n.

Exemple[edit | edit source]

Exemplul 1[edit | edit source]

Intrare
5 2
7 3 9 1 6
Ieșire
Datele sunt introduse corect.
7 9 1 6

Exemplul 2[edit | edit source]

Intrare
4 5
Ieșire
Datele nu corespund restricțiilor impuse.


Rezolvare[edit | edit source]

<syntaxhighlight lang="python" line>

  1. 1452 Stergere Element

def stergere_element(X, n, p):

   for i in range(p - 1, n - 1):
       X[i] = X[i + 1]
   n -= 1
   for i in range(n):
       print(X[i], end=" ")


def citire_conform_restrictiilor(n, p, X):

   if n < 1 or n > 1500 or p < 1 or p > 1500 or p > n:
       print("Datele nu corespund restricțiilor impuse.")
       exit()
   if n != len(X):
       print("Datele nu corespund restricțiilor impuse.")
       exit()
   for element in X:
       if element >= 1000000 or element <= -1000000:
           print("Datele nu corespund restricțiilor impuse.")
           exit()
   print("Datele sunt introduse corect.")


if __name__ == '__main__':

   n, p = map(int, input().split())
   X = list(map(int, input().split()))
   citire_conform_restrictiilor(n, p, X)
   stergere_element(X, n, p)




</syntaxhighlight>

Explicație rezolvare[edit | edit source]

   Programul de mai sus conține două funcții, funcția stergere_element(X, n, p) și funcția citire_conform_restrictiilor(n, p, X), care se vor rula în interiorul main-ului (if __name__ == '__main__' , linia 25) după citirea numerelor n, p (linia 26) și cele n numere pe care le vom pune în șirul „X” (linia 27).
După ce am citit elementele, se va apela funcția citire_conform_restrictiilor(n, p, X) care primește trei parametri: n, p, X. Funcția verifică mai întâi dacă n este între 1 și 1500 și dacă p este mai mic decât 1500 și este mai mare decât n (linia 12), dacă n este lungimea vectorului X (linia 15) și dacă elementele vectorului sunt cuprinse între -1.000.000 și 1.000.000 (liniile 18, 19). Dacă oricare dintre condiții este încălcată, se va afișa mesajul „Datele nu corespund restricțiilor impuse.” și se va ieși din program cu comanda exit(). Dacă toate condițiile sunt respectate, se va afișa mesajul „Datele sunt introduse corect.” (linia 22) și se va continua programul.
Dacă s-au introdus corect datele, se va apela funcția stergere_element(X, n, p) care primește ca parametrii vectorul X și numerele n, p. Această funcție începe cu un for care începe de pe poziția p-1 (deoarece vectorul nostru începe de pe poziția 0) și mută toate elementele cu o poziție înainte (liniile 4, 5). Apoi, se decrementează cu unul 1 numărul n, deoarece se scoate un element din vector, așadar lungimea sa va scădea cu 1. În final, afișăm elementele din vectorul X cu un for care ia elementele de la 1 la noul n (liniile 7, 8), separate cu un spațiu.