1723 - Culegere 1: Difference between revisions

From Bitnami MediaWiki
Sinn Erich (talk | contribs)
Sinn Erich (talk | contribs)
Line 33: Line 33:
== Rezolvare ==  
== Rezolvare ==  
<syntaxhighlight lang="python" line>
<syntaxhighlight lang="python" line>
#4273
#1723
def patrate_perfecte(n):
import math
    patrate = []
    i = 1
    while len(patrate) < n:
        patrat = i * i
        patrate.append(patrat)
        i += 1
    return patrate


 
def validate_input(p, n):
def calculeaza(numbers):
     if not 1 <= p <= 16000 or not 1 <= n <= 2112600000:
     product = 1
    for number in numbers:
        product *= number
    return product
 
 
def validare_numar(n):
    if n < 1 or n > 10:
         return False
         return False
     return True
     return True


if __name__ == '__main__':
    # read input values
    p, n = map(int, input().split())


if __name__ == '__main__':
     # validate input values
     n = int(input("Introduceți numărul n: "))
     if not validate_input(p, n):
     if not validare_numar(n):
         print("Input values do not meet the requirements.")
         print("Datele introduse nu corespund cerintelor.")
     else:
     else:
         squares = patrate_perfecte(n)
         # calculate the total number of problems in the first P pages
         product = calculeaza(squares)
         total_problems = sum(range(1, p+1))
         print("Datele introduse corespund cerintelor.")
 
         print(product)
         # calculate the number of pages needed to include problem N
         n_page = ((3 + 8 * (n - 1)) ** 0.5 - 1) // 2 + 1


        # calculate the total number of digits used to number all the problems in the collection
        total_digits = sum(len(str(i)) for i in range(1, total_problems + 1))


        # print the values of T and M
        print(total_digits)
        print(int(n_page))
</syntaxhighlight>
</syntaxhighlight>
'''Explicatie cod:'''
Acest cod are două funcții principale: validate_input() și main().
Funcția validate_input() verifică dacă valorile primite ca parametri sunt în intervalul specificat de probleme. Dacă valoarea nu este validă, funcția returnează False, altfel returnează True.
Funcția main() citește valorile de intrare, verifică dacă sunt valide prin apelul funcției validate_input(). Dacă valorile sunt invalide, se afișează un mesaj de eroare. În caz contrar, se calculează numărul total de probleme în primele p pagini, numărul de pagini necesare pentru a include problema n și numărul total de cifre folosite pentru numerotarea tuturor problemelor din colecție. La final, aceste valori sunt afișate pe ecran.

Revision as of 20:34, 2 April 2023

Sursa: [1]

Cerinţa

O culegere de probleme are P pagini, numerotate de la 1 la P. Problemele din culegere sunt numerotate cu 1,2,3,...,etc, în ordinea apariţiei lor în culegere. Pe prima pagină a culegerii este scrisă o singură problemă (cea cu numărul 1). Pe a doua pagină sunt scrise exact două probleme (cele cu numerele 2 şi 3, în această ordine). Pe cea de-a treia pagină sunt scrise exact trei probleme (cele cu numerele 4, 5 şi 6, în această ordine),…, pe cea de a P-a pagină sunt scrise exact P probleme.

Scrieţi un program care citeşte numerele naturale P şi N şi determină valorile: a) T, numărul total de cifre care au fost utilizate în numerotarea tuturor problemelor din culegere; b) M, numărul minim de pagini pe care ar trebui să le aibă culegerea, astfel încât aceasta să conţină şi problema numerotată cu N.

Date de intrare

Programul conţine pe prima linie cele două numere naturale P şi N, separate printr-un spaţiu, cu semnificaţia din enunţ.

Date de ieșire

Programul conţine: pe prima linie numărul natural T, cu semnificaţia din enunţ; pe a doua linie numărul natural M, cu semnificaţia din enunţ.

Dacă datele sunt introduse corect, programul va rula.

Î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

1 ≤ P ≤ 16000 1 ≤ N ≤ 2112600000

Exemplul 1

Intrare
5 9
21
4


Rezolvare

<syntaxhighlight lang="python" line>

  1. 1723

import math

def validate_input(p, n):

   if not 1 <= p <= 16000 or not 1 <= n <= 2112600000:
       return False
   return True

if __name__ == '__main__':

   # read input values
   p, n = map(int, input().split())
   # validate input values
   if not validate_input(p, n):
       print("Input values do not meet the requirements.")
   else:
       # calculate the total number of problems in the first P pages
       total_problems = sum(range(1, p+1))
       # calculate the number of pages needed to include problem N
       n_page = ((3 + 8 * (n - 1)) ** 0.5 - 1) // 2 + 1
       # calculate the total number of digits used to number all the problems in the collection
       total_digits = sum(len(str(i)) for i in range(1, total_problems + 1))
       # print the values of T and M
       print(total_digits)
       print(int(n_page))

</syntaxhighlight>

Explicatie cod:

Acest cod are două funcții principale: validate_input() și main().

Funcția validate_input() verifică dacă valorile primite ca parametri sunt în intervalul specificat de probleme. Dacă valoarea nu este validă, funcția returnează False, altfel returnează True.

Funcția main() citește valorile de intrare, verifică dacă sunt valide prin apelul funcției validate_input(). Dacă valorile sunt invalide, se afișează un mesaj de eroare. În caz contrar, se calculează numărul total de probleme în primele p pagini, numărul de pagini necesare pentru a include problema n și numărul total de cifre folosite pentru numerotarea tuturor problemelor din colecție. La final, aceste valori sunt afișate pe ecran.