0246 - Ultimele Impare: Difference between revisions

From Bitnami MediaWiki
Sinn Erich (talk | contribs)
Pagină nouă: Sursa: [https://www.pbinfo.ro/probleme/4273/prodpp] == Cerinţa == Se dă numărul natural nenul '''n'''. Să se determine produsul primelor '''n''' pătrate perfecte nenule. == Date de intrare == Programul citește de la tastatură numărul '''n'''. == Date de ieșire == Programul va afișa pe ecran, mesajul "Datele introduse corespund cerințelor" și pe o linie nouă numărul '''P''' , reprezentând produsul primelor '''n''' pătrate perfecte nenule, în caz contrar prog...
 
Sinn Erich (talk | contribs)
 
(11 intermediate revisions by the same user not shown)
Line 1: Line 1:
Sursa: [https://www.pbinfo.ro/probleme/4273/prodpp]
Sursa: [https://www.pbinfo.ro/probleme/4273/prodpp]
== Cerinţa ==
== Cerinţa ==
Se dă numărul natural nenul '''n'''. Să se determine produsul primelor '''n''' pătrate perfecte nenule.
Se dau '''n''' numere naturale. Să se determine ultimele două numere impare, nu neapărat distincte, dintre cele date.
 
== Date de intrare ==
== Date de intrare ==
Programul citește de la tastatură numărul '''n'''.
Programul citeşte de la tastatură numărul '''n''', apoi '''n''' numere naturale, dispuse pe mai multe linii.
 
== Date de ieșire ==  
== Date de ieșire ==  
Programul va afișa pe ecran, mesajul "Datele introduse corespund cerințelor" și pe o linie nouă numărul '''P''' , reprezentând produsul primelor '''n''' pătrate perfecte nenule, în caz contrar programul va afișa pe o linie noua mesajul "Datele introduse nu corespund cerintelor."
Programul afişează pe ecran ultimele două numere impare dintre cele date, în ordinea în care au fost citite. Dacă nu au fost citite suficiente numere impare, se va afişa doar mesajul Numere insuficiente.


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ă ultimele două numere impare, nu neapărat distincte, dintre cele date. 


Î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 ==
* 0 < '''n''' ⩽ 10
0 < '''n''' <= 10.000
 
cele n numere citite vor avea cel mult 9 cifre


== Exemplul 1 ==
== Exemplul 1 ==
; Intrare
; Datele de intrare
: 4
:Introduceti numarul n: 8
; Ieșire
:Introduceti numarul 1: 12
: Datele corespund cerințelor.
:Introduceti numarul 2: 15
: 576
:Introduceti numarul 3: 68
:Introduceti numarul 4: 13
:Introduceti numarul 5: 17
:Introduceti numarul 6: 90
:Introduceti numarul 7: 31
:Introduceti numarul 8: 42
; Datele de ieșire
: Datele sunt introduse corect.
: (17, 31)
<br>
<br>


== Rezolvare ==
<syntaxhighlight lang="python" line>
#0246
def ultimele_doua_numere_impare(n, numere):
    # Inițializăm cu două numere pare negative, astfel încât să putem distinge cazul în care nu găsim două numere impare
    ultimul_impar = -2
    penultimul_impar = -2


    # Parcurgem numerele în ordine inversă, până găsim cele două numere impare
    for numar in reversed(numere):
        if numar % 2 != 0:
            if ultimul_impar == -2:
                ultimul_impar = numar
            elif penultimul_impar == -2:
                penultimul_impar = numar
                break


== Rezolvare ==
    # Returnăm cele două numere impare, sau un mesaj de eroare dacă nu au fost găsite suficiente
<syntaxhighlight lang="python" line>
    if penultimul_impar != -2:
#4273
        return penultimul_impar, ultimul_impar
def patrate_perfecte(n):
    else:
     patrate = []
        return "Datele nu corespund restricțiilor impuse."
     i = 1
 
    while len(patrate) < n:
 
         patrat = i * i
if __name__ == "__main__":
         patrate.append(patrat)
    n = int(input("Introduceti numarul n: "))
        i += 1
     numere = []
    return patrate
     for i in range(n):
         numar = int(input(f"Introduceti numarul {i+1}: "))
         numere.append(numar)


    rezultat = ultimele_doua_numere_impare(n, numere)
    print("Datele sunt introduse corect.")
    print(rezultat)


def calculeaza(numbers):
</syntaxhighlight>
    product = 1
    for number in numbers:
        product *= number
    return product


'''Explicatie cod:'''


def validare_numar(n):
Acest cod definește o funcție numită "ultimele_doua_numere_impare" care primește ca argumente numărul n și o listă de n numere. Scopul funcției este să găsească ultimele două numere impare din listă, în ordinea în care au fost introduse.
    if n < 1 or n > 10:
        return False
    return True


Inițial, funcția inițializează două variabile numite "ultimul_impar" și "penultimul_impar" cu valoarea -2. Acestea vor fi utilizate pentru a stoca cele două numere impare găsite. Valoarea -2 a fost aleasă pentru că este un număr negativ și nu va fi întâlnit în mod normal în lista dată.


if __name__ == '__main__':
Apoi, funcția parcurge lista de numere în ordine inversă, până când găsește cele două numere impare. Dacă găsește un număr impar, îl verifică pe "ultimul_impar" și "penultimul_impar" pentru a vedea dacă a fost deja găsit un număr impar anterior. Dacă "ultimul_impar" nu a fost încă setat, numărul impar curent este atribuit acestei variabile. Dacă "ultimul_impar" este setat, dar "penultimul_impar" nu este, numărul impar curent este atribuit acestei variabile și funcția iese din bucla for utilizând instrucțiunea "break".
    n = int(input("Introduceți numărul n: "))
    if not validare_numar(n):
        print("Datele introduse nu corespund cerintelor.")
    else:
        squares = patrate_perfecte(n)
        product = calculeaza(squares)
        print("Datele introduse corespund cerintelor.")
        print(product)


În cele din urmă, funcția returnează cele două numere impare găsite în ordine inversă, sau un mesaj de eroare "Numere insuficiente" dacă nu au fost găsite suficiente numere impare în listă.


</syntaxhighlight>
În blocul "if name == 'main'", programul citește numărul n și apoi citeste n numere de la tastatură, adăugându-le în lista "numere". Apoi, funcția "ultimele_doua_numere_impare" este apelată cu aceste argumente, iar rezultatul este afișat la consolă.

Latest revision as of 07:15, 27 April 2023

Sursa: [1]

Cerinţa[edit | edit source]

Se dau n numere naturale. Să se determine ultimele două numere impare, nu neapărat distincte, dintre cele date.

Date de intrare[edit | edit source]

Programul citeşte de la tastatură numărul n, apoi n numere naturale, dispuse pe mai multe linii.

Date de ieșire[edit | edit source]

Programul afişează pe ecran ultimele două numere impare dintre cele date, în ordinea în care au fost citite. Dacă nu au fost citite suficiente numere impare, se va afişa doar mesajul Numere insuficiente.

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele sunt introduse corect.", apoi pe un rând nou afișează ultimele două numere impare, nu neapărat distincte, dintre cele date.

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

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

0 < n <= 10.000

cele n numere citite vor avea cel mult 9 cifre

Exemplul 1[edit | edit source]

Datele de intrare
Introduceti numarul n: 8
Introduceti numarul 1: 12
Introduceti numarul 2: 15
Introduceti numarul 3: 68
Introduceti numarul 4: 13
Introduceti numarul 5: 17
Introduceti numarul 6: 90
Introduceti numarul 7: 31
Introduceti numarul 8: 42
Datele de ieșire
Datele sunt introduse corect.
(17, 31)


Rezolvare[edit | edit source]

<syntaxhighlight lang="python" line>

  1. 0246

def ultimele_doua_numere_impare(n, numere):

   # Inițializăm cu două numere pare negative, astfel încât să putem distinge cazul în care nu găsim două numere impare
   ultimul_impar = -2
   penultimul_impar = -2
   # Parcurgem numerele în ordine inversă, până găsim cele două numere impare
   for numar in reversed(numere):
       if numar % 2 != 0:
           if ultimul_impar == -2:
               ultimul_impar = numar
           elif penultimul_impar == -2:
               penultimul_impar = numar
               break
   # Returnăm cele două numere impare, sau un mesaj de eroare dacă nu au fost găsite suficiente
   if penultimul_impar != -2:
       return penultimul_impar, ultimul_impar
   else:
       return "Datele nu corespund restricțiilor impuse."


if __name__ == "__main__":

   n = int(input("Introduceti numarul n: "))
   numere = []
   for i in range(n):
       numar = int(input(f"Introduceti numarul {i+1}: "))
       numere.append(numar)
   rezultat = ultimele_doua_numere_impare(n, numere)
   print("Datele sunt introduse corect.")
   print(rezultat)

</syntaxhighlight>

Explicatie cod:

Acest cod definește o funcție numită "ultimele_doua_numere_impare" care primește ca argumente numărul n și o listă de n numere. Scopul funcției este să găsească ultimele două numere impare din listă, în ordinea în care au fost introduse.

Inițial, funcția inițializează două variabile numite "ultimul_impar" și "penultimul_impar" cu valoarea -2. Acestea vor fi utilizate pentru a stoca cele două numere impare găsite. Valoarea -2 a fost aleasă pentru că este un număr negativ și nu va fi întâlnit în mod normal în lista dată.

Apoi, funcția parcurge lista de numere în ordine inversă, până când găsește cele două numere impare. Dacă găsește un număr impar, îl verifică pe "ultimul_impar" și "penultimul_impar" pentru a vedea dacă a fost deja găsit un număr impar anterior. Dacă "ultimul_impar" nu a fost încă setat, numărul impar curent este atribuit acestei variabile. Dacă "ultimul_impar" este setat, dar "penultimul_impar" nu este, numărul impar curent este atribuit acestei variabile și funcția iese din bucla for utilizând instrucțiunea "break".

În cele din urmă, funcția returnează cele două numere impare găsite în ordine inversă, sau un mesaj de eroare "Numere insuficiente" dacă nu au fost găsite suficiente numere impare în listă.

În blocul "if name == 'main'", programul citește numărul n și apoi citeste n numere de la tastatură, adăugându-le în lista "numere". Apoi, funcția "ultimele_doua_numere_impare" este apelată cu aceste argumente, iar rezultatul este afișat la consolă.