0948 - Calendar 2: Difference between revisions
Pagină nouă: == Cerinta == Fermierului Ion îi place să-și organizeze activitățile din timp. Chiar prea mult. Acesta ajunge să-și facă planuri și pentru câțiva ani. Singura dilemă pe care o are acesta este în ce zi a săptămânii va cădea data pe care își propune să efectueze respectiva activitate. Preocuparea sa este atât de mare încât se întreabă și de evenimente care au avut loc în trecut. == Date de intrare == Programul citește de la tastatură numărul o... |
|||
(2 intermediate revisions by the same user not shown) | |||
Line 7: | Line 7: | ||
== Date de intrare == | == Date de intrare == | ||
Programul citește de la tastatură numărul o dată calendaristică, formată din 3 numere naturale Z, L și A reprezentând ziua, luna și anul. | Programul citește de la tastatură numărul o dată calendaristică, formată din 3 numere naturale '''Z, L și A''' reprezentând ziua, luna și anul. | ||
== Date de iesire == | == Date de iesire == | ||
Line 15: | Line 15: | ||
== Restrictii si precizari == | == Restrictii si precizari == | ||
*1 | *1 ⩽ Z ⩽ 31 | ||
*1 | *1 ⩽ L ⩽ 12 | ||
*1900 | *1900 ⩽ A ⩽ 2100 | ||
*Nu se vor cere zile invalide precum 29 februarie 2015 sau 31 noiembrie 1980 | *Nu se vor cere zile invalide precum 29 februarie 2015 sau 31 noiembrie 1980 | ||
Line 24: | Line 24: | ||
:6 1 2015 | :6 1 2015 | ||
;Iesire | ;Iesire | ||
:Datele introduse corespund restrictiilor impuse | |||
:Marti | :Marti | ||
Line 31: | Line 31: | ||
:31 2 3100 | :31 2 3100 | ||
;Iesire | ;Iesire | ||
:Datele introduse nu corespund restrictiilor impuse | |||
Line 44: | Line 44: | ||
J = A // 100 | J = A // 100 | ||
numar_zi = (Z + 13 * (L + 1) // 5 + K + K // 4 + J // 4 - 2 * J) % 7 | |||
zile_saptamana = ["Duminica", "Luni", "Marti", "Miercuri", "Joi", "Vineri", "Sambata"] | |||
zile_saptamana = [ | return zile_saptamana[numar_zi] | ||
return | def verifica_restrictii(Z, L, A): | ||
if 1 <= Z <= 31 and 1 <= L <= 12 and 1900 <= A <= 2100: | |||
return True | |||
else: | |||
return False | |||
# Citire date de intrare | |||
Z, L, A = map(int, input().split()) | |||
# | # Verificare restricții | ||
if verifica_restrictii(Z, L, A): | |||
# Rezolvare și afișare rezultat | |||
rezultat = ziua_saptamanii(Z, L, A) | rezultat = ziua_saptamanii(Z, L, A) | ||
print("Datele introduse corespund restrictiilor impuse") | |||
print(rezultat) | print(rezultat) | ||
else: | |||
print("Date de intrare nevalide!") | |||
</syntaxhighlight> | </syntaxhighlight> |
Latest revision as of 12:12, 29 December 2023
Cerinta[edit | edit source]
Fermierului Ion îi place să-și organizeze activitățile din timp. Chiar prea mult. Acesta ajunge să-și facă planuri și pentru câțiva ani. Singura dilemă pe care o are acesta este în ce zi a săptămânii va cădea data pe care își propune să efectueze respectiva activitate.
Preocuparea sa este atât de mare încât se întreabă și de evenimente care au avut loc în trecut.
Date de intrare[edit | edit source]
Programul citește de la tastatură numărul o dată calendaristică, formată din 3 numere naturale Z, L și A reprezentând ziua, luna și anul.
Date de iesire[edit | edit source]
Programul va afișa pe ecran una din zilele săptămânii (Luni, Marti, Miercuri, Joi, Vineri, Sambata, Duminica) semnificând ziua săptămânii corespunzătoare datei cerute.
Restrictii si precizari[edit | edit source]
- 1 ⩽ Z ⩽ 31
- 1 ⩽ L ⩽ 12
- 1900 ⩽ A ⩽ 2100
- Nu se vor cere zile invalide precum 29 februarie 2015 sau 31 noiembrie 1980
Exemplul 1[edit | edit source]
- Intrare
- 6 1 2015
- Iesire
- Datele introduse corespund restrictiilor impuse
- Marti
Exemplul 2[edit | edit source]
- Intrare
- 31 2 3100
- Iesire
- Datele introduse nu corespund restrictiilor impuse
Rezolvare[edit | edit source]
<syntaxhighlight lang="python3" line="1"> def ziua_saptamanii(Z, L, A):
if L < 3: L += 12 A -= 1
K = A % 100 J = A // 100
numar_zi = (Z + 13 * (L + 1) // 5 + K + K // 4 + J // 4 - 2 * J) % 7
zile_saptamana = ["Duminica", "Luni", "Marti", "Miercuri", "Joi", "Vineri", "Sambata"] return zile_saptamana[numar_zi]
def verifica_restrictii(Z, L, A):
if 1 <= Z <= 31 and 1 <= L <= 12 and 1900 <= A <= 2100: return True else: return False
- Citire date de intrare
Z, L, A = map(int, input().split())
- Verificare restricții
if verifica_restrictii(Z, L, A):
# Rezolvare și afișare rezultat rezultat = ziua_saptamanii(Z, L, A) print("Datele introduse corespund restrictiilor impuse") print(rezultat)
else:
print("Date de intrare nevalide!")
</syntaxhighlight>