1581 - Max Suma: Diferență între versiuni

De la Universitas MediaWiki
 
(Nu s-au afișat 9 versiuni intermediare efectuate de un alt utilizator)
Linia 9: Linia 9:
Se vor scrie pe fiecare rând pentru fiecare şir '''cel mai mare număr''' din şir şi '''suma'''.
Se vor scrie pe fiecare rând pentru fiecare şir '''cel mai mare număr''' din şir şi '''suma'''.


Dacă datele sunt introduse corect, programul va rula.
Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele sunt introduse corect.", apoi pe un rând nou afișează cel mai mare număr din fiecare şir. Să se determine suma numerelor fiecărui şir.  


În cazul în care datele nu respectă restricțiile, se va afișa pe ecran: ''' "Datele nu corespund restricțiilor impuse.".'''
În caz contrar, se va afișa pe ecran: "Datele nu corespund restricțiilor impuse."


== Restricţii şi precizări ==
== Restricţii şi precizări ==
Linia 19: Linia 19:


== Exemplul 1 ==
== Exemplul 1 ==
; Intrare
; Datele de intrare:
: Introduceti numarul de siruri:
: 3  
: 3  
:5
: Introduceti numarul maxim de numere dintr-un sir:
: 5
: Introduceti sirul de numere separate prin spatiu:
:15 25 44 66 87
:15 25 44 66 87
: Introduceti sirul de numere separate prin spatiu:
:25 11 44 78 32
:25 11 44 78 32
: Introduceti sirul de numere separate prin spatiu:
:20 59 87 45 99
:20 59 87 45 99
; Ieșire
; Datele de ieșire:
:87 237
:Datele sunt introduse corect.
:78 190
:Sirul 0:
:99 310
:Cel mai mare numar: 87
:Suma numerelor: 237
:Sirul 1:
:Cel mai mare numar: 78
:Suma numerelor: 190
:Sirul 2:
:Cel mai mare numar: 99
:Suma numerelor: 310
<br>
<br>


Linia 34: Linia 46:
<syntaxhighlight lang="python" line>
<syntaxhighlight lang="python" line>
#1581
#1581
def read_input():
def validate_input(n, m):
     """
     """
     Citeste datele de intrare si returneaza lista de siruri de numere.
     Verifica daca valorile introduse pentru n si m respecta
    restricțiile impuse.
     """
     """
    if not (1 <= n <= 100):
        print("Datele nu corespund restricțiilor impuse.")
        return False
    if not (1 <= m <= 50):
        print("Datele nu corespund restricțiilor impuse.")
        return False
    return True
def max_and_sum(sir):
    """
    Gaseste cel mai mare numar din sir si suma tuturor numerelor.
    """
    max_numar = max(sir)
    suma = sum(sir)
    return max_numar, suma
def print_result(max_numar, suma, i):
    """
    Afiseaza rezultatele pentru sirul cu indicele i.
    """
    print(f"Sirul {i}:")
    print(f"Cel mai mare numar: {max_numar}")
    print(f"Suma numerelor: {suma}")
    print()
def solution_function(n, m, siruri_numere):
    """
    Functia de rezolvare a problemei.
    """
    for i, sir in enumerate(siruri_numere):
        max_numar, suma = max_and_sum(sir)
        print_result(max_numar, suma, i)
if __name__ == '__main__':
     n = int(input("Introduceti numarul de siruri: "))
     n = int(input("Introduceti numarul de siruri: "))
    m = int(input("Introduceti numarul maxim de numere dintr-un sir: "))
    print("Datele sunt corecte.")
    if not validate_input(n, m):
        exit()
     siruri_numere = []
     siruri_numere = []
     for i in range(n):
     for i in range(n):
Linia 44: Linia 96:
         numere = sir.split()
         numere = sir.split()
         numere_int = [int(x) for x in numere]
         numere_int = [int(x) for x in numere]
        if len(numere_int) > m:
            print("Datele nu corespund restricțiilor impuse.")
            exit()
         siruri_numere.append(numere_int)
         siruri_numere.append(numere_int)
    return siruri_numere
def max_and_sum(sir):
    """
    Gaseste cel mai mare numar si suma numerelor dintr-un sir.
    """
    max_numar = 0
    suma = 0
    for numar in sir:
        if numar > max_numar:
            max_numar = numar
        suma += numar
    return max_numar, suma
def print_result(max_numar, suma, index):
    """
    Afiseaza cel mai mare numar si suma numerelor dintr-un sir,
    impreuna cu numarul sirului.
    """
    print("Cel mai mare numar din sirul", index+1, "este:", max_numar)
    print("Suma numerelor din sirul", index+1, "este:", suma)
siruri_numere = read_input()


for i, sir in enumerate(siruri_numere):
     solution_function(n, m, siruri_numere)
    max_numar, suma = max_and_sum(sir)
 
     print_result(max_numar, suma, i)


</syntaxhighlight>
</syntaxhighlight>
Linia 75: Linia 109:


Acest cod citeste n siruri de numere separate prin spatiu, apoi pentru fiecare sir de numere calculeaza cel mai mare numar si suma tuturor numerelor din sir.
Acest cod citeste n siruri de numere separate prin spatiu, apoi pentru fiecare sir de numere calculeaza cel mai mare numar si suma tuturor numerelor din sir.
Functia read_input() citeste numarul de siruri de numere, iar apoi citeste fiecare sir de numere, il transforma intr-o lista de intregi si adauga lista la o lista generala siruri_numere. Aceasta lista este returnata la final.


Functia max_and_sum(sir) primeste un sir de numere si calculeaza cel mai mare numar din sir si suma tuturor numerelor din sir. Pentru aceasta, initializeaza max_numar cu 0 si suma cu 0, apoi parcurge fiecare numar din sir, actualizand valorile max_numar si suma corespunzator. La final, functia returneaza cele doua valori.
Functia max_and_sum(sir) primeste un sir de numere si calculeaza cel mai mare numar din sir si suma tuturor numerelor din sir. Pentru aceasta, initializeaza max_numar cu 0 si suma cu 0, apoi parcurge fiecare numar din sir, actualizand valorile max_numar si suma corespunzator. La final, functia returneaza cele doua valori.

Versiunea curentă din 29 aprilie 2023 17:28

Sursa: [1]

Cerinţa

Se dau n şiruri, fiecare şir fiind format din m numere naturale mai mici decat 500. Să se determine cel mai mare număr din fiecare şir. Să se determine suma numerelor fiecărui şir.

Date de intrare

Programul citeste pe rând n, m şi restul numerelor.

Date de ieșire

Se vor scrie pe fiecare rând pentru fiecare şir cel mai mare număr din şir şi suma.

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele sunt introduse corect.", apoi pe un rând nou afișează cel mai mare număr din fiecare şir. Să se determine suma numerelor fiecărui şir.

În caz contrar, se va afișa pe ecran: "Datele nu corespund restricțiilor impuse."

Restricţii şi precizări

1 ≤ n ≤ 100

1 ≤ m ≤ 50

Exemplul 1

Datele de intrare
Introduceti numarul de siruri:
3
Introduceti numarul maxim de numere dintr-un sir:
5
Introduceti sirul de numere separate prin spatiu:
15 25 44 66 87
Introduceti sirul de numere separate prin spatiu:
25 11 44 78 32
Introduceti sirul de numere separate prin spatiu:
20 59 87 45 99
Datele de ieșire
Datele sunt introduse corect.
Sirul 0:
Cel mai mare numar: 87
Suma numerelor: 237
Sirul 1:
Cel mai mare numar: 78
Suma numerelor: 190
Sirul 2:
Cel mai mare numar: 99
Suma numerelor: 310


Rezolvare

#1581
def validate_input(n, m):
    """
    Verifica daca valorile introduse pentru n si m respecta
    restricțiile impuse.
    """
    if not (1 <= n <= 100):
        print("Datele nu corespund restricțiilor impuse.")
        return False
    if not (1 <= m <= 50):
        print("Datele nu corespund restricțiilor impuse.")
        return False
    return True

def max_and_sum(sir):
    """
    Gaseste cel mai mare numar din sir si suma tuturor numerelor.
    """
    max_numar = max(sir)
    suma = sum(sir)
    return max_numar, suma

def print_result(max_numar, suma, i):
    """
    Afiseaza rezultatele pentru sirul cu indicele i.
    """
    print(f"Sirul {i}:")
    print(f"Cel mai mare numar: {max_numar}")
    print(f"Suma numerelor: {suma}")
    print()

def solution_function(n, m, siruri_numere):
    """
    Functia de rezolvare a problemei.
    """
    for i, sir in enumerate(siruri_numere):
        max_numar, suma = max_and_sum(sir)
        print_result(max_numar, suma, i)

if __name__ == '__main__':
    n = int(input("Introduceti numarul de siruri: "))
    m = int(input("Introduceti numarul maxim de numere dintr-un sir: "))
    print("Datele sunt corecte.")
    if not validate_input(n, m):
        exit()

    siruri_numere = []
    for i in range(n):
        sir = input("Introduceti sirul de numere separate prin spatiu: ")
        numere = sir.split()
        numere_int = [int(x) for x in numere]
        if len(numere_int) > m:
            print("Datele nu corespund restricțiilor impuse.")
            exit()
        siruri_numere.append(numere_int)

    solution_function(n, m, siruri_numere)

Explicatie cod:

Acest cod citeste n siruri de numere separate prin spatiu, apoi pentru fiecare sir de numere calculeaza cel mai mare numar si suma tuturor numerelor din sir.

Functia max_and_sum(sir) primeste un sir de numere si calculeaza cel mai mare numar din sir si suma tuturor numerelor din sir. Pentru aceasta, initializeaza max_numar cu 0 si suma cu 0, apoi parcurge fiecare numar din sir, actualizand valorile max_numar si suma corespunzator. La final, functia returneaza cele doua valori.

Functia print_result(max_numar, suma, index) primeste cel mai mare numar si suma numerelor dintr-un sir, impreuna cu numarul sirului, si le afiseaza.

In main, se citesc sirurile de numere folosind read_input(), apoi se parcurg sirurile folosind enumerate(siruri_numere) pentru a retine si indexul fiecarui sir. Pentru fiecare sir, se calculeaza cel mai mare numar si suma numerelor folosind max_and_sum(sir), iar apoi se afiseaza aceste valori folosind print_result(max_numar, suma, i), unde i este indexul sirului.