Spécification du programme
Étant donnée une date de la forme « jour mois année », il faut écrire un programme qui donne le jour de la semaine correspondant. Le programme compilé devra être invoqué de la façon suivante sur la ligne de commande :
On rappelle qu’à l’invite du shell
chaque élément de texte délimité par des espaces est transmis au programme appelé sous forme de chaîne de caractères, et que le programme Scheme les reçoit sous forme d’une liste de chaînes de caractères, ainsi :
Il faudra donc convertir en nombres les chaînes "27"
, "10"
et "2003"
.
Afin de rendre l’exercice plus stimulant, nous voudrions que le programme soit également capable d’effectuer ce calcul pour le calendrier julien, en vigueur dans certaines églises orthodoxes et orientales, ainsi que dans les livres d’histoire de la révolution russe. Nous ajouterons donc un argument facultatif "J"
[1] pour calculer le jour de la semaine qui correspond à une date selon le calendrier julien :
Ce quatrième argument sera converti en symbole au sens de Scheme.
Selon le calendrier julien, les années multiples de 4 sont bissextiles. Selon le calendrier grégorien, en vigueur depuis le 15 octobre 1582 dans les pays dont la religion d’État était à l’époque le catholicisme, les années multiples de 4 sont bissextiles, sauf les années séculaires (multiples de 100), cependant que les années multiples de 400 restent bissextiles.
On donne deux dates de référence qui sont tombées un lundi : le 1er janvier 2018 pour le calendrier grégorien, le 23 janvier 2018 pour le calendrier julien.
Un excellent site calendaire suisse permettra de vérifier la justesse des calculs, et de découvrir d’autres calendriers plus ou moins compliqués qui pourront fournir des exercices amusants.
Récupération de la ligne de commande
Le programme sera réalisé sous la forme d’un module Bigloo, dont voici le début :
Les éléments de la ligne de commande sont transmis à un programme Scheme sous la forme d’une liste. Les opérations disponibles pour les listes permettent d’en extraire le premier élément (car
) ou d’en conserver la fin privée du premier élément (cdr
). Pour extraire ou supprimer le dernier élément d’une liste, il faut opérer sur la liste retournée, par la procédure (reverse
).
Année bissextile
Les calendriers julien et grégorien diffèrent par les règles de détermination des années bissextiles. Nous pouvons en déduire le prédicat Bissextile?
qui calcule si une année est bissextile ou non, et la procédure Bissextile
qui calcule la valeur à ajouter au nombre de jours de l’année selon que l’année est bissextile ou non :
Munis de ces procédures nous pouvons, étant donnés une année et un mois, calculer le nombre de jours de ce mois :
Type abstrait date
Les dates seront représentées dans le programme par des listes de quatre éléments :
calendrier
vaut J si on calcule dans le calendrier julien, G pour le calendrier grégorien.
Nous pouvons considérer cette représentation comme un type abstrait date
, et voici son constructeur et les accesseurs pour les différents champs :
Procédures utilitaires
Calculer le nombre de jours d’un mois donné d’une année donnée :
Déterminer si une date donnée est antérieure à une date de référence :
Pour deux dates dont les millésimes diffèrent de 2 ou plus (années non égales et non consécutives), calculer la somme des nombres de jours des années entières entre ces deux dates :
Pour une date donnée, quel est le rang du jour dans l’année ?
Pour une date donnée, le nombre de jours restants jusqu’à la fin de l’année :
Calcul final
Pour deux dates données, combien de jours entre elles ?
Et enfin, étant données une date et une date de référence dont on connaît le jour de la semaine, calculer le jour de la semaine auquel elle tombe :