0948 - Calendar 2
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 dată calendaristică, formată din 3 numere naturale Z, L și A reprezentând ziua, luna și anul.
Date de iesire
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
- 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
- Intrare
- 6 1 2015
- Iesire
- Datele introduse corespund restrictiilor impuse
- Marti
Exemplul 2
- Intrare
- 31 2 3100
- Iesire
- Datele introduse nu corespund restrictiilor impuse
Rezolvare
<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>