Approf
Approf
Approf
Chapitre 3
Les structures de contrôle:
approfondissements
Nous allons reprendre dans ce chapitre, l'étude des structures de contrôle . Dans un
premier temps, nous étudierons d'autres structures que celles que l'on a étudié jusqu'à
présent. Ensuite, nous verrons comment on peut imbriquer les structures de contrôle et
par la même occasion, nous étudierons la programmation descendante.
Voilà l'algorithme qui affiche le mois en toute lettre selon son numéro.
Le numéro du mois en mémorisé dans la variable mois.
1
Stéphanie Laporte Algo: Chap 3 Lycée Louise Michel BTS 1 IG
Exemple 2: Les différents cas possibles sont décrits par des intervalles de valeur
(taux de remise différent selon le montant d'achat)
…
Selon montant Faire
<1000 : taux ! 1
≥1000 et < 3000: taux ! 2
≥3000 et < 10000: taux ! 3
≥ 10000: taux ! 4
FinSelon
montant ! montant * ( 1 – taux/100)
…
B. La boucle Répéter…Jusqu'à
Cette boucle sert à répéter une instruction jusqu'à ce qu'une condition (expression
booléenne) soit vraie. Son formalisme est le suivant:
Répéter
Le traitement est exécuté, puis la condition est vérifiée. Si elle n'est pas vraie, on
retourne au début de la boucle et le traitement est répété. Si la condition est vraie, on
sort de la boucle et le programme continue séquentiellement. A chaque fois que le
traitement est exécuté, la condition d'arrêt est de nouveau vérifiée à la fin.
" Exemple:
Programme Aire
Var
rayon : réel
réponse : chaîne
Début
Afficher "Calcul de l'aire d'un cercle"
Répéter
Afficher "Entrez le rayon d'un cercle en cm"
Saisir rayon
Afficher "L'aire de ce cercle est ", rayon*rayon *3.14, "cm²"
Afficher "Voulez-vous l'aire d'un autre cercle? (oui/non)"
Saisir réponse
Jusqu'à réponse ≠ "oui" //si la réponse est différente de "oui", la répétition du traitement s'arrête
Afficher "Au revoir!"
Fin
La boucle Répéter n'est pas indispensable. Elle peut toujours être remplacée par une
boucle Tantque. C'est pourquoi certains langages n'ont pas d'équivalent pour la boucle
Répéter.
2
Stéphanie Laporte Algo: Chap 3 Lycée Louise Michel BTS 1 IG
Vrai
test traitement
Faux
traitement
test
Faux
Vrai
suite
suite
Voilà un programme qui fait la même chose que l'exemple 2 sur la structure Selon, mais
utilisant l'imbrication des structures Si.
Programme taux
Var
montant, taux: entiers
Début
Si montant < 1000 //(1)
Alors taux ! 1
Sinon Si montant < 3000 //(2)
Alors taux ! 2
Sinon Si montant < 10000 //(3)
Alors taux ! 3
Sinon taux !4
Finsi //(3)
Finsi //(2)
Finsi //(1)
Montant ! montant - montant * taux/100
Afficher montant
Fin
Si le montant est inférieur à 1000, la valeur 1 est affectée au taux et le programme passe
à l'instruction suivante. Attention, l'instruction suivante n'est pas celle qui suit Sinon.
3
Stéphanie Laporte Algo: Chap 3 Lycée Louise Michel BTS 1 IG
Si la condition est vérifiée, tout ce qui suit le Sinon est ignoré, y compris les Si qui sont
imbriqués dans le Sinon. Donc le programme passe à l'instruction suivante qui est
montant ! montant - montant * taux/100
En ce qui concerne la présentation, nous avons décalé vers la gauche les structures
imbriquées. C'est une convention d'écriture qu'on retrouve pour toutes les structures, et
qui a pour but de rendre l'algorithme plus lisible.
#Les structures imbriquées sont emboîtées telles des poupées russes. Il est
impossible qu'elles se chevauchent.
Cela est valable pour les structures conditionnelles et pour toutes les autres structures.
Dans ce cas, le premier FinSi rencontré dans l'algorithme indique toujours la fin de la
structure la plus imbriquée. Il est donc inutile de numéroter les structures pour
reconnaître où elles se terminent.
Représentation schématique:
4
Stéphanie Laporte Algo: Chap 3 Lycée Louise Michel BTS 1 IG
Si on inclut cette séquence à l'intérieur d'une boucle qui se répète 3 fois, on va effectuer 3
fois l'affichage de 5 étoiles donc on va obtenir l'affichage de 15 étoiles.
$ L'imbrication des boucles multiplie les tours de boucles
*****
*****
*****
La boucle la plus imbriquée s'exécute alors que la "grande" boucle s'exécute seulement 3
fois. Le compteur i varie 5 fois plus vite que le compteur j.
Trace
j=1 j=2 j=3
i=1 i=2 i=3 i=4 i=5 i=1 i=2 i=3 i=4 i=5 i=1 i=2 i=3 i=4 i=5
* * * * * * * * * * * * * * *
Tous les types de boucles peuvent s'imbriquer entre eux. La seule règle à respecter est
que les boucles ne doivent pas se chevaucher: elles doivent s'emboîter. Si vous
respectez bien la règle des décalages, vous ne pouvez pas vous tromper.
OK IMPOSSIBLE
5
Stéphanie Laporte Algo: Chap 3 Lycée Louise Michel BTS 1 IG
Voilà un programme qui calcule le chiffre d'affaire annuel d'un représentant à partir de
la saisie des 12 chiffres d'affaire mensuels. Le programme permet de recommencer le
calcul avec un autre représentant si l'utilisateur tape le caractère 'o' (pour oui).
Programme CA
Var
CAM : réel //chiffre d'affaire mensuel
CAA : réel //chiffre d'affaire annuel
mois : entier //compteur de la boucle qui calcule le CA annuel
réponse : caractère
Début
Répéter
Afficher "Veuillez entrer les 12 chiffres d'affaire mensuels d'un représentant"
CAA ! 0 //réinitialisation du CA annuel pour chaque représentant.
Pour mois de 1 jusqu'à 12 Faire
Saisir CAM
CAA ! CAA + CAM //cumul
FinPour
Afficher "Chiffre d'affaire annuel :" , CAA
Afficher "Voulez-vous calculer le chiffre d'affaire annuel d'un autre représentant?"
Saisir réponse
Jusqu'à réponse ≠ 'o'
Fin
L'imbrication des boucles n'est pas compliquée si on pense à bien décomposer les
problèmes, du général au particulier (c'est l'approche descendante). Pour cela, il faut
procéder à une analyse du problème sans rentrer dans les détails de l'algorithme. On
réfléchit d'abord à QUOI faire avant de réfléchir à COMMENT faire.
Répéter
calculer le chiffre d'affaire d'un représentant et l'afficher
demander à l'utilisateur s'il veut continuer
Jusqu'à ce qu'il ne réponde pas 'o' (recommencer tant qu'il répond 'o')
On veut écrire un algorithme qui calcule et affiche les 10 tables de multiplication (de 1 à
10).
Chaque table doit être présentée comme exemple de la table du 7 ci-dessous:
La table du 7 est:
1*7=7
2 * 7 = 14
3 * 7 = 21
4 * 7 = 28
5 * 7 = 35
6
Stéphanie Laporte Algo: Chap 3 Lycée Louise Michel BTS 1 IG
6 * 7 = 42
7 * 7 = 49
8 * 7 = 56
9 * 7 = 63
10 * 7 = 70
Dans notre problème, nous constatons qu'il s'agit d'afficher 10 tables de multiplication, le
numéro de la table augmentant d'un à chaque fois: on va donc utiliser une boucle Pour.
Pour écrire la table des n, on affiche d'abord le libellé, puis on utilise une boucle pour
chaque nombre de 1 à 10.
# ATTENTION : n est le numéro de la table, donc on ne peut pas l'utiliser comme
compteur dans la boucle des 10 nombres. On va plutôt utiliser l comme ligne
Programme tables
Var
n: entier //numéro de la table
l : entier // ligne de la table
Début
Pour n de 1 jusqu'à 10 Faire
Afficher "La table du", n, "est :"
Pour l de 1 jusqu'à 10 Faire
Afficher l, " * ", n, " = ", l *n
FinPour
FinPour
Fin
7
Stéphanie Laporte Algo: Chap 3 Lycée Louise Michel BTS 1 IG
TANT QUE <condition d'exécution> FAIRE REPETER POUR <variable> DE <valeur intiale>
JUSQU'A <valeur finale> PAS DE
<traitement (corps de la boucle)> <traitement (corps de la boucle)> <incrément> FAIRE
&'Le corps de la boucle n'est exécuté que si la &'Le corps de la boucle est exécuté au moins FINPOUR
condition est vraie. Il peut ne jamais être une fois
exécuté. &'La valeur de l'expression évaluée dans la &'Le nombre de fois où la boucle sera exécuté
&'La valeur de l'expression évaluée dans la condition d'exécution doit devenir vraie est connu d'avance
condition d'exécution doit devenir fausse pour sortir de la boucle. &'<variable> est augmentée de l'incrément à
pour sortir de la boucle. chaque tour de boucle
Programme exemple
Var Programme exemple
n, cpt :entiers /* n est la valeur pour laquelle la boucle Var Programme exemple
doit s'arrêter et cpt est le compteur*/
n, cpt :entier /* n est la valeur pour laquelle la boucle Var
Début doit s'arrêter et cpt est le compteur*/ n, cpt :entiers /* n est la valeur pour laquelle la boucle
/*initialisations*/ doit s'arrêter et cpt est le compteur*/
Début
Saisir n /* initialisations*/ Début
cpt ! 1 Saisir n /* initialisations*/
/* boucle*/
cpt ! 0 Saisir n
Tantque cpt <= n Faire /*boucle*/ /*boucle*/
Afficher cpt Répéter Pour cpt de 1 jqà n Faire
cpt ! cpt + 1 cpt ! cpt + 1 Afficher cpt
Fintantque Afficher cpt Finpour
Fin Jusqu'à cpt = n Fin
Fin