0551 - Elevi: Diferență între versiuni

De la Universitas MediaWiki
(Pagină nouă: Sursa: https://www.pbinfo.ro/probleme/551/elevi 0551- Elevi] ---- == Cerinţa == La liceul nostru sunt '''m''' clase, fiecare având '''n''' elevi. Pentru fiecare elev se cunoaşte talentul artistic, exprimat printr-un număr natural. Să se determine cea mai mare valoare pe care o are talentul artistic al elevilor, notată cu '''MAX''' şi numărul '''CNT''' de clase din liceu în care există elevi care au talent maxim. == Date de intrare == Programul citește de la tastatu...)
 
mFără descriere a modificării
 
(Nu s-a afișat o versiune intermediară efectuată de un alt utilizator)
Linia 25: Linia 25:
; Ieșire
; Ieșire
: Datele sunt introduse corect.
: Datele sunt introduse corect.
: 25 25 15 15
: 6 3
===Exemplul 2===
===Exemplul 2===
; Intrare
; Intrare
Linia 36: Linia 36:
# 0551
# 0551


def citire_cu_restrictii_m_n():
def citire_cu_restrictii_m_n(m, n):
    n, m = map(int, input().split())
     if n < 1 or n > 1000:
     if n < 1 or n > 1000:
         print("Datele nu corespund restricțiilor impuse.")
         print("Datele nu corespund restricțiilor impuse.")
Linia 44: Linia 43:
         print("Datele nu corespund restricțiilor impuse.")
         print("Datele nu corespund restricțiilor impuse.")
         exit()
         exit()
    return m, n




Linia 76: Linia 74:


if __name__ == '__main__':
if __name__ == '__main__':
     m, n = citire_cu_restrictii_m_n()
     n, m = map(int, input().split())
    citire_cu_restrictii_m_n(m, n)
     prelucrare_max_cnt(m, n)
     prelucrare_max_cnt(m, n)


Linia 93: Linia 92:
</syntaxhighlight>
</syntaxhighlight>
== Explicație rezolvare==
== Explicație rezolvare==
: Acest cod definește trei funcții și un bloc if __name__ == '__main__': care apelează aceste funcții în funcție de anumite condiții. Iată un rezumat al fiecărei funcții:
    Acest cod definește trei funcții și o secțiune '''if __name__ == '__main__':'''(linia 40) care apelează aceste funcții după citirea numerelor n și m cu ajutorul comenzii de citire input() și cea de conversie în număr int() (linia 41).<br>  Funcția '''citire_cu_restrictii_m_n(m, n)''' primește doi parametri, m și n, și verifică dacă aceștia îndeplinesc restricțiile impuse. Dacă n nu este între 1 și 1000 sau m nu este între 1 și 100, se afișează "Datele nu corespund restricțiilor impuse." și se încheie programul prin apelul funcției exit().<br>  Funcția '''verificare_vectori_conform_restrictiilor(vector)''' primește un vector de numere și verifică dacă acestea îndeplinesc restricțiile impuse. Dacă un element din vector este mai mare decât 1000000 sau mai mic decât 1, se afișează "Datele nu corespund restricțiilor impuse." și se încheie programul prin apelul funcției exit().<br>  Funcția '''prelucrare_max_cnt(m, n)''' primește doi parametri, m și n, și efectuează o prelucrare de date. Se creează un vector gol de lungime 1001 cu vector = [0] * 1001. Apoi se citește n linii de input, fiecare conținând m numere separate prin spațiu, și se stochează în vector. Pentru fiecare linie, se găsește cel mai mare element din acea linie și se compară cu maximul global (MAX). Dacă acesta este mai mare decât maximul global curent, se actualizează maximul global și se resetează contorul (CNT) la 1. Dacă este egal cu maximul global curent, se incrementează contorul. La final, se afișează "Datele sunt introduse corect." și pe un rând nou MAX și CNT, conform problemei.
 
1. '''citire_cu_restrictii_m_n()''': Această funcție cere utilizatorului să introducă două numere întregi separate prin spațiu și verifică dacă acestea corespund anumitor restricții. Dacă valorile introduse sunt în afara acestor restricții, funcția va afișa un mesaj de eroare și va încheia programul prin apelarea funcției exit(). În caz contrar, funcția va returna cele două valori ca o tuplă.
 
2. '''verificare_vectori_conform_restrictiilor(vector)''': Această funcție primește un vector ca parametru și verifică dacă valorile acestuia corespund unor restricții impuse. Dacă valorile sunt în afara acestor restricții, funcția va afișa un mesaj de eroare și va încheia programul prin apelarea funcției exit().
 
3. '''prelucrare_max_cnt(m, n)''': Această funcție primește doi parametri, m și n, și prelucrează datele introduse de utilizator. Funcția va citi n vectori de lungime m de la tastatură și va găsi valoarea maximă din fiecare vector. Dacă valoarea maximă a unui vector este mai mare decât valoarea maximă găsită până atunci, funcția va actualiza această valoare maximă și va reseta contorul. Dacă valoarea maximă este aceeași cu valoarea maximă găsită anterior, funcția va incrementa contorul. La final, funcția va afișa un mesaj de confirmare și valorile maxime și contorul calculat.
 
Funcția '''citire_cu_restrictii_m_n()''' este apelată în blocul if __name__ == '__main__': pentru a citi valorile m și n și pentru a verifica dacă acestea corespund restricțiilor. Dacă valorile sunt corecte, funcția '''prelucrare_max_cnt()''' este apelată pentru a prelucra datele introduse.

Versiunea curentă din 26 aprilie 2023 12:04

Sursa: https://www.pbinfo.ro/probleme/551/elevi 0551- Elevi]


Cerinţa

La liceul nostru sunt m clase, fiecare având n elevi. Pentru fiecare elev se cunoaşte talentul artistic, exprimat printr-un număr natural. Să se determine cea mai mare valoare pe care o are talentul artistic al elevilor, notată cu MAX şi numărul CNT de clase din liceu în care există elevi care au talent maxim.

Date de intrare

Programul citește de la tastatură numerele m n, iar apoi m şiruri cu câte n numere naturale, reprezentând talentul fiecărui elev din fiecare clasă.

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 numerele MAX CNT, separate prin exact un spaţiu, cu semnificaţia precizată. Î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

  • 1n1000
  • 1m100
  • talentul artistic al unui elev este un număr natural mai mic decât 1.000.000

Exemple

Exemplul 1

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

Exemplul 2

Intrare
-1 12
Ieșire
Datele nu corespund restricțiilor impuse.


Rezolvare

# 0551

def citire_cu_restrictii_m_n(m, n):
    if n < 1 or n > 1000:
        print("Datele nu corespund restricțiilor impuse.")
        exit()
    if m < 1 or m > 100:
        print("Datele nu corespund restricțiilor impuse.")
        exit()


def verificare_vectori_conform_restrictiilor(vector):
    for element in vector:
        if element > 1000000 or element < 1:
            print("Datele nu corespund restricțiilor impuse.")
            exit()


def prelucrare_max_cnt(m, n):
    vector = [0] * 1001
    MAX, CNT = -1, 0
    for k in range(1, n+1):
        vector = list(map(int, input().split()))

        cmaxim = vector[0]

        for i in range(m):
            if vector[i] > cmaxim:
                cmaxim = vector[i]

        if cmaxim > MAX:
            MAX = cmaxim
            CNT = 1
        elif cmaxim == MAX:
            CNT += 1
    print("Datele sunt introduse corect.")
    print(MAX, CNT)


if __name__ == '__main__':
    n, m = map(int, input().split())
    citire_cu_restrictii_m_n(m, n)
    prelucrare_max_cnt(m, n)

Explicație rezolvare

   Acest cod definește trei funcții și o secțiune if __name__ == '__main__':(linia 40) care apelează aceste funcții după citirea numerelor n și m cu ajutorul comenzii de citire input() și cea de conversie în număr int() (linia 41).
Funcția citire_cu_restrictii_m_n(m, n) primește doi parametri, m și n, și verifică dacă aceștia îndeplinesc restricțiile impuse. Dacă n nu este între 1 și 1000 sau m nu este între 1 și 100, se afișează "Datele nu corespund restricțiilor impuse." și se încheie programul prin apelul funcției exit().
Funcția verificare_vectori_conform_restrictiilor(vector) primește un vector de numere și verifică dacă acestea îndeplinesc restricțiile impuse. Dacă un element din vector este mai mare decât 1000000 sau mai mic decât 1, se afișează "Datele nu corespund restricțiilor impuse." și se încheie programul prin apelul funcției exit().
Funcția prelucrare_max_cnt(m, n) primește doi parametri, m și n, și efectuează o prelucrare de date. Se creează un vector gol de lungime 1001 cu vector = [0] * 1001. Apoi se citește n linii de input, fiecare conținând m numere separate prin spațiu, și se stochează în vector. Pentru fiecare linie, se găsește cel mai mare element din acea linie și se compară cu maximul global (MAX). Dacă acesta este mai mare decât maximul global curent, se actualizează maximul global și se resetează contorul (CNT) la 1. Dacă este egal cu maximul global curent, se incrementează contorul. La final, se afișează "Datele sunt introduse corect." și pe un rând nou MAX și CNT, conform problemei.