1581 - Max Suma: Difference between revisions

From Bitnami MediaWiki
Sinn Erich (talk | contribs)
 
(9 intermediate revisions by one other user not shown)
Line 9: Line 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 ==
Line 19: Line 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>


Line 34: Line 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):
Line 44: Line 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>
Line 75: Line 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.

Latest revision as of 17:28, 29 April 2023

Sursa: [1]

Cerinţa[edit | edit source]

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[edit | edit source]

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

Date de ieșire[edit | edit source]

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[edit | edit source]

1 ≤ n ≤ 100

1 ≤ m ≤ 50

Exemplul 1[edit | edit source]

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[edit | edit source]

<syntaxhighlight lang="python" line>

  1. 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)


</syntaxhighlight>

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.