1040 - Clepsidru
O clepsidră este un dispozitiv folosit pentru a măsura timpul. Clepsidra este alcătuită din două incinte de sticlă, conectate printr-un tub fin. Una dintre incinte este umplută cu nisip, acesta scurgându-se în cea de-a doua incintă, cu o viteză constantă. Clepsidra poate fi întoarsă, pentru a măsura o altă perioadă de timp.
Arheologii au descoperit un dispozitiv, pe care l-au denumit clepsidru, format din n
clepsidre identice, suprapuse, numerotate de la 1
la n
, prin care nisipul poate circula de la o clepsidră la alta datorită forţei gravitaţionale.
Studiind acest obiect, arheologii au constatat că :
- dispozitivul poate fi utilizat atât în poziţia
1
, când clepsidrele sunt în ordinea1
,2
,…,n
cu clepsidran
aşezată pe sol, cât şi în poziţia2
, când clepsidrele sunt în ordinean
,n-1
,…,1
cu clepsidra1
aşezată pe sol; - viteza de trecere a nisipului de la o incintă la alta, a aceleiaşi clepsidre, este de
1
bob de nisip/secundă, pentru toate clepsidrele, indiferent de poziţie; - trecerea clepsidrului dintr-o poziţie în alta presupune răsturnarea acestuia şi reaşezarea boabelor de nisip;
- timpul de trecere a boabelor de nisip de la o clepsidră la alta este 0.
Arheologii studiază comportarea clepsidrului realizând două experimente diferite, după cum urmează:
a) Se aşează clepsidrul în poziţia 1
, se introduc în incinta de sus a clepsidrei 1
un număr b
de boabe de nisip şi se determină după câte secunde vor ajunge toate boabele de nisip în incinta de jos a ultimei clepsidre;
b) Se aşează clepsidrul în poziţia 1
, se introduc în incinta de sus a clepsidrei 1
un număr b
de boabe de nisip, apoi se aşează clepsidrul în k
stări consecutive, o stare fiind caracterizată de valorile si
şi pi
, 1 ≤ i ≤ k
, ce reprezintă numărul de secunde, respectiv poziţia, în care este menţinut nemişcat clepsidrul, iar la final se determină numărul de boabe de nisip din incintele fiecărei clepsidre.
Spre exemplu, dacă clepsidrul este format din n=2
clepsidre, iar în incinta de sus a primei clepsidre se introduc b=3
boabe de nisip, la primul experiment se va obţine valoarea 4
.
La al doilea experiment se aşează clepsidrul în k=2
stări, caracterizate prin s1=3
, p1=1
; s2=1
, p2=2
.
Numărul de boabe de nisip din clepsidre va evolua ca în figura alăturată.
Cerința
Să se scrie un program care citeşte valorile n
şi b
, precum şi valorile k
, si
, pi
, 1 ≤ i ≤ k
, şi calculează valorile obţinute de arheologi la realizarea celor două experimente.
Date de intrare
Fișierul de intrare clepsidru.in
conține pe prima linie două numere naturale nenule n
şi b
, separate printr-un singur spaţiu, cu semnificaţia din enunţ; a doua linie conţine numărul natural nenul k
având semnificaţia din enunţ, iar următoarele k
linii conţin fiecare câte o pereche de valori si
şi pi
, 1 ≤ i ≤ k
, separate printr-un singur spaţiu, cu semnificaţia din enunţ.
Date de ieșire
Fișierul de ieșire clepsidru.out
va conține pe prima linie un număr natural ce reprezintă valoarea obţinută la primul experiment, iar pe următoarele n
linii va conţine câte o pereche de numere naturale, separate printr-un singur spaţiu, ce reprezintă cantităţile de boabe de nisip din incintele de sus şi de jos ale celor n
clepsidre, scrise în ordinea de la 1
la n
a clepsidrelor, după realizarea celui de-al doilea experiment.
Restricții și precizări
1 ≤ n ≤ 1 000
;1 ≤ b ≤ 1 000 000 000
;1 ≤ k ≤ 1 000
;1 ≤ si ≤ 1 000
,1 ≤ i ≤ k
;pi
aparține{1, 2}
,1 ≤ i ≤ k
;- pentru rezolvarea corectă a primei cerinţe se acordă
25%
din punctaj, iar pentru rezolvarea corectă a celei de-a doua cerinţe se acordă75%
din punctaj.
Exemplu:
clepsidru.in
2 3 2 3 1 1 2
clepsidru.out
4 1 1 0 1
Explicație
- Clepsidrul este format din
n=2
clepsidre şi în incinta de sus a primei clepsidre se introducb=3
boabe de nisip. - Toate boabele de nisip vor ajunge în incinta de jos a ultimei clepsidre după
4
secunde. - După ce clepsidrul este aşezat
3
secunde în poziţia1
şi1
secundă în poziţia2
, în clepsidre se vor găsi câte(1,1)
,(0,1)
boabe de nisip - <syntaxhighlight lang="python" line="1">
def experiment1(n, b):
return b + (n - 1)
def experiment2(n, b, k, states):
# Initializare clepsidre = [0] * n clepsidre[0] = b for si, pi in states: if pi == 1: # poziția inițială for _ in range(si): for i in range(n-1, 0, -1): transfer = min(clepsidre[i-1], 1) clepsidre[i] += transfer clepsidre[i-1] -= transfer elif pi == 2: # poziția inversată for _ in range(si): for i in range(1, n): transfer = min(clepsidre[i], 1) clepsidre[i-1] += transfer clepsidre[i] -= transfer
return clepsidre
- Citirea input-ului
n = int(input("Introduceti numarul de clepsidre: ")) b = int(input("Introduceti numarul de boabe de nisip: ")) k = int(input("Introduceti numarul de stari: ")) states = []
for _ in range(k):
si = int(input("Introduceti numarul de secunde pentru starea curenta: ")) pi = int(input("Introduceti pozitia pentru starea curenta: ")) states.append((si, pi))
- Rezultatele experimentelor
timp_experiment1 = experiment1(n, b) rezultat_experiment2 = experiment2(n, b, k, states)
print(f"Timpul pentru experimentul 1: {timp_experiment1}") print("Numarul de boabe de nisip in fiecare clepsidra dupa experimentul 2:") for i, boabe in enumerate(rezultat_experiment2, 1):
print(f"Clepsidra {i}: {boabe} boabe")
</syntaxhighlight>