CHAPITRE 3 : Les boucles de répétition
Une boucle permet de répéter un même traitement, une ou plusieurs fois. Le
langage C offre trois sortes de boucles :
do ... while (Répéter ...),
while ... (Tant que ...) et
for ... (Pour ...)
A)Boucle do ... while ... (Répéter .... Tant que)
1) Syntaxe
do instruction
instruction
while (condition);
faux vrai
condition
L'instruction à répéter peut être simple (une seule action), structurée (une
autre instruction de contrôle) ou composée (c'est le cas le plus fréquent).
Exemples pour illustrer la syntaxe :
int somme = 0;
int n = 1;
/* instruction à répéter est composée */
do {
somme += n;
n++;
} while (n <= 10);
int indice = 0;
/* instruction à répéter est simple */
do
indice++;
while (indice < 5);
Chapitre 3 : Boucles de répétition 54
Préparé par Le Van N. pour IFT 1810
int age;
/* instruction à répéter est structurée */
do {
if (age >= 18)
printf("C'est un adulte");
else
age += 5;
} while (age < 18);
int age;
/* instruction à répéter est composée */
do {
printf("age = %d\n", age);
if (age >= 18)
printf("C'est un adulte");
else
age += 5;
} while (age < 18);
2) Fonctionnement
Étape 1 : Effectuer (d'abord) l'instruction à répéter.
Étape 2 : Vérifier (après) la condition:
a) si la condition est vrai, on revient à l'étape 1;
b) si non (la condition est faux), on quitte la boucle.
Conclusion :
Avec la boucle do ... while, on effectue au moins une fois l'instruction à
répéter.
3) Domaines d'utilisation
On utilise la boucle do ... while quand on ne sait pas à l'avance le nombre
de fois que l'on doit répéter le même traitement. Les exemples suivants
permettent de voir quelques applications possibles avec cette boucle.
Chapitre 3 : Boucles de répétition 55
Préparé par Le Van N. pour IFT 1810
1.1 Répéter le même traitement en mode conversationnel
C'est le cas le plus fréquent pour le premier travail pratique en IFT
1810.
Exemple :
Écrire un bloc d'instructions permettant de saisir l'âge et le sexe d'une
personne. Ensuite, on affiche un message du genre :
C'est un enfant de sexe masculin.
On répète le même traitement tant que l'usager décide de continuer.
Solution :
int age;
char sexe,
reponse; /* Oui ou Non l'usager veut continuer */
do {
printf("\nEntrez le sexe et l'age ");
scanf(" %c%d", &sexe, &age);
printf("C'est un ");
if (age <= 11)
printf("enfant ");
else if (age < 18)
printf("adolescent ");
else
printf("adulte ");
if (toupper(sexe) == 'F') /* to upper : en majuscule */
printf("de sexe feminin\n");
else
printf("de sexe masculin\n");
printf("\nVoulez-vous continuer ? (O/N) ");
scanf(" %c", &reponse);
} while (toupper(reponse) == 'O');
Chapitre 3 : Boucles de répétition 56
Préparé par Le Van N. pour IFT 1810
Exercice :
Écrire un bloc d'instructions permettant de saisir le prix d'un article (un
réel). Ensuite, on calcule les taxes TPS et TVQ et on affiche à l'écran
les informations du genre :
Prix de l'article : ....
Taxe TPS : ....
Taxe TVQ : ....
Prix total à payer : ....
On répète le même traitement tant que l'usager décide de continuer.
1.2 Validation de données
La boucle do ... while permet de valider la valeur que l'usager entre au
clavier.
Exemple :
Écrire un bloc d'instructions permettant de saisir et de valider :
le sexe d'une personne ('f', 'F', 'm' ou 'M');
l'âge d'une personne (entre 1 et 134).
Une solution possible :
const int MAXI_AGE = 134;
int age;
char sexe;
/* saisir et valider le sexe */
do {
printf("Entrez un caractere parmi f, F, m ou M :");
scanf(" %c", &sexe);
if (sexe != 'f' && sexe != 'F' &&
sexe != 'm' && sexe != 'M')
printf("Erreur! Retapez S.V.P. \n");
} while (sexe != 'f' && sexe != 'F' &&
sexe != 'm' && sexe != 'M');
/* saisir et valider l'âge */
do {
printf("Entrez l'age entre 1 et %d : ", MAXI_AGE);
scanf("%d", &age);
if (age < 1 || age > MAXI_AGE)
printf("Erreur! Retapez S.V.P. \n");
} while (age < 1 || age > MAXI_AGE);
Une solution plus élégante :
Chapitre 3 : Boucles de répétition 57
Préparé par Le Van N. pour IFT 1810
const int MAXI_AGE = 134;
int age, valide; /* Oui ou Non la donnée est valide */
char sexe;
/* saisir et valider le sexe */
do {
printf("Entrez un caractere parmi f, F, m ou M :");
scanf(" %c", &sexe);
sexe = toupper(sexe);
valide = (sexe == 'F' || sexe == 'M');
if (!valide) /* Si Pas valide */
printf("Erreur! Retapez S.V.P. \n");
} while (!valide); /* tant que non valide */
/* saisir et valider l'âge */
do {
printf("Entrez l'âge entre 1 et %d : ", MAXI_AGE);
scanf("%d", &age);
valide = (age >= 1 && age <= MAXI_AGE);
if (!valide)
printf("Erreur! Retapez S.V.P. \n");
} while (!valide);
Calcul scientifique
Exemple 1
Écrire un bloc d'instructions permettant de calculer et d'afficher la
somme suivante :
somme = 10 + 15 + 20 + 25 + ... + 50
Solution
const int BORNE1 = 10,
BORNE2 = 50,
LEPAS = 5;
int terme, somme;
somme = 0;
terme = BORNE1;
do {
somme += terme; /*équivalent à : somme = somme + terme ; */
Chapitre 3 : Boucles de répétition 58
Préparé par Le Van N. pour IFT 1810
terme += LEPAS;
} while (terme <= BORNE2);
printf("La somme calculee est : %d\n", somme);
Exemple 2
Écrire un programme permettant d'estimer la valeur de PI
(3.1416...) selon la formule suivante :
PI
4 1 13 15 17 19 19999
Solution
#include <stdio.h>
void main()
{
const int LIMITE = 9999,
LEPAS = 2;
int denominateur = 1; /* premier dénominateur vaut 1 */
float piSur4 = 0.0, signe = 1.0;
do {
piSur4 += signe / denominateur;
signe = -signe; /* changer de signe */
denominateur += LEPAS;
} while (denominateur <= LIMITE);
printf("La valeur estimee de PI est %12.6f\n",
4 * piSur4);
}
Exécution
La valeur estimee de PI est 3.141397
Chapitre 3 : Boucles de répétition 59
Préparé par Le Van N. pour IFT 1810
4) Exercices
Exercice 1
Écrire un programme permettant de saisir et de valider si un entier lu (exemple
7234) est positif ou non. Ensuite, on affiche l'entier tel que lu en plus d'afficher
cet entier lu à l'inverse (ici 4327).
Solution :
#include <stdio.h>
int main()
{
int n;
/* Saisie et validation */
do {
printf("Entrez un entier positif : ");
scanf("%d", &n);
if (n < 0)
printf("n = %d est negatif\n", n);
} while (n < 0);
printf("L'entier lu : %d\n", n);
printf("A l'envers : ");
do {
printf("%d", n % 10);
n /= 10;
} while (n > 0);
return 0;
}
Exécution
Entrez un entier positif : –8742
n = -8742 est negatif
Entrez un entier positif : 5329
L'entier lu : 5329
A l'envers : 9235
Chapitre 3 : Boucles de répétition 60
Préparé par Le Van N. pour IFT 1810
Exercice 2
Écrire un programme permettant de saisir un entier positif (exemple 5426). Il
calcule l'envers du nombre lu (ici 6245) et affiche ces deux valeurs.
Solution :
#include <stdio.h>
int main()
{
int n, envers;
printf("Entrez un entier positif : ");
scanf("%d", &n);
printf("L'entier lu : %d\n", n);
/* Calcul de l'envers */
envers = 0;
do {
envers = 10 * envers + n % 10;
n /= 10;
/* Attention au écriture raccourcie,
* ici on peut écrire
* envers *= 10;
* envers += nombre % 10;
* mais on ne doit pas écrire
* envers *= 10 + nombre % 10;
* qui nous donne pas le même résultat
*/
} while (n > 0);
printf("A l'envers : %d", envers);
return 0 ;
}
Exécution
Entrez un entier positif :1234
L'entier lu : 1234
A l'envers : 4321
Exercice 3
Écrire un programme permettant de saisir les informations d'un placement :
le capital (un réel)
le taux d'intérêt (composé) annuel en %
Le programme calcule et affiche l'évolution du placement, année après année.
Lorsque notre épargne vaut un million ou plus, l'exécution du programme
s'arrête. Ce programme permet donc d'évaluer combien d'années cela prendra
pour devenir millionnaire si l'on adopte un tel plan d'épargne.
Chapitre 3 : Boucles de répétition 61
Préparé par Le Van N. pour IFT 1810
/* Dans combien d'années, deviendra-t'on millionnaire ?
Matière : boucle do ... while (entre autres) */
#include <stdio.h>
int main()
{
const float SEUIL_RICHESSE_VOULU = 1000000.00;
float depotAnnuel, /* montant fixe de dépôt annuel */
taux, /* taux d'intérêt annuel espéré */
interetAnnuel, /* intérêt annuel à la fin de l'année qui
s’ajoute au capital à la fin de l'année
(intérêt composé) */
capital; /* capital accumulé, année après année */
int nbAnnee; /* compteur du nombre d'années */
/* Saisie les données : montant de dépôt et le taux d'intérêt */
printf("Quel est le montant de depot annuel (exemple 1000.00) ? ");
scanf("%f", &depotAnnuel);
printf("Quel est le taux annuel fixe espere (ex. 7.5) ? ");
scanf("%f", &taux);
/* traitement : */
if (depotAnnuel >= SEUIL_RICHESSE_VOULU)
printf("Vous avez atteint ou depasse le seuil %10.2f
$\n",SEUIL_RICHESSE_VOULU);
else {
/* affichage de l'en-tête pour résumer l'évolution du placement
*/
printf("\n\nFONDS XYZ inc.\n");
printf("Montant de depot annuel : %6.2f $\n", depotAnnuel);
printf("Taux d'interet annuel (suppose fixe) : %4.2f\n", taux);
printf("\n\nEvolution du placement :\n\n");
printf("Annee Capital (au debut) Interet annuel",
" Capital (a la fin de l'annee)\n");
nbAnnee = 0;
capital = 0;
do {
/* début d'une année de placement */
nbAnnee++;
/* capital accumulé au début de l'année de placement */
capital += depotAnnuel;
printf("%3d %12.2f", nbAnnee, capital);
/* à la fin de l'année de placement : */
interetAnnuel = taux / 100.0 * capital;
/* ajouter l'intérêt au capital pour une autre année */
capital += interetAnnuel;
printf("%25.2f %18.2f\n", interetAnnuel, capital);
} while (capital < SEUIL_RICHESSE_VOULU);
printf("\nApres %d annee(s), votre capital sera : %12.2f $\n",
Chapitre 3 : Boucles de répétition 62
Préparé par Le Van N. pour IFT 1810
nbAnnee, capital);
}
return 0 ;
}
Exécution
Quel est le montant de depot annuel (exemple 1000.00) ? 1234567
Quel est le taux annuel fixe espere (ex. 7.5) ? 5.00
Vous avez atteint ou depasse le seuil 1000000.00 $
Press any key to continue
Quel est le montant de depot annuel (exemple 1000.00) ? 3000
Quel est le taux annuel fixe espere (ex. 7.5) ? 10.0
FONDS XYZ inc.
Montant de depot annuel : 3000.00 $
Taux d'interet annuel (suppose fixe) : 10.00
Evolution du placement :
Annee Capital (au debut) Interet annuel Capital (a la fin de
l'annee)
1 3000.00 300.00 3300.00
2 6300.00 630.00 6930.00
3 9930.00 993.00 10923.00
etc.
. . . . . . . .
35 813073.00 81307.30 894380.30
36 897380.31 89738.03 987118.34
37 990118.38 99011.84 1089130.21
Apres 37 annee(s), votre capital sera : 1089130.25 $
Chapitre 3 : Boucles de répétition 63
Préparé par Le Van N. pour IFT 1810
Autres exemples
Exemple 1
/* Boucle do ... while
Application 1 :
"Répéter le même traitement TANT QUE l'usager décide de continuer
"
Ce programme permet :
de saisir la taille d'une personne en nombre de pieds et de
pouces
de convertir cette taille en mètre
d'afficher la taille dans les deux systèmes
Le programme fonctionne pour plusieurs personnes
tant que l'usager décide de continuer.
*/
#include <stdio.h>
int main()
{
const float FACTEUR = 0.3048; /* 1 pied = 0.3048 mètre */
char reponse; /* Oui ou Non si l'usager veut continuer */
int nbPieds, nbPouces;
float taille;
do { /* Répéter */
/* Saisie la taille en nombre de pieds et de pouces */
printf("Entrez la taille en nombre de pieds et de pouces : ");
scanf("%d%d", &nbPieds, &nbPouces);
/* Conversion en mètre : */
taille = (nbPieds + nbPouces / 12.0) * FACTEUR;
/* Affichage : */
printf("La taille de la personne :\n");
printf(" %d pied(s) et %d pouce(s)\n", nbPieds, nbPouces);
printf(" %4.2f metre\n", taille);
/* Demander si l'usager veut continuer */
printf("\nVoulez-vous continuer ? (o/n) ");
scanf(" %c", &reponse);
} while (reponse == 'o' || reponse == 'O');
return 0;
}
Exécution
Entrez la taille en nombre de pieds et de pouces : 5 6
Chapitre 3 : Boucles de répétition 64
Préparé par Le Van N. pour IFT 1810
La taille de la personne :
5 pied(s) et 6 pouce(s)
1.68 metre
Voulez-vous continuer ? (o/n) o
Entrez la taille en nombre de pieds et de pouces : 6 2
La taille de la personne :
6 pied(s) et 2 pouce(s)
1.88 metre
Voulez-vous continuer ? (o/n) o
Entrez la taille en nombre de pieds et de pouces : 4 9
La taille de la personne :
4 pied(s) et 9 pouce(s)
1.45 metre
Voulez-vous continuer ? (o/n) n
Exemple 2
/* Fichier dowhile2.c
Deuxième application de la boucle do ... while
Répéter
saisir une donnée
Si la donnée est invalide
afficher un message pertinent
Tant que (la donnée est invalide)
Ce programme permet :
1. de saisir et VALIDER un poste de travail parmi les 4 postes
2. de saisir et VALIDER l'ancienneté entre 2 bornes
3. d'afficher un message approprié
*/
#include <stdio.h>
#include <ctype.h>
int main()
{
const int MIN_ANC = 1,
MAX_ANC = 25;
char poste; /* parmi : A, P, O et S analyste, programmeur,
opérateur, secrétaire */
int anciennete; /* nb. d'années d'ancienneté */
int valide; /* Oui ou Non l'ancienneté est valide */
/* Saisir et valider le poste de travail : */
do {
printf("Entrez un caractere representant le poste de travail :
");
scanf(" %c", &poste);
poste = toupper(poste);
Chapitre 3 : Boucles de répétition 65
Préparé par Le Van N. pour IFT 1810
if (poste != 'A' && poste != 'P' && poste != 'O' && poste != 'S')
printf("Poste invalide, retapez S.V.P.\n\n");
} while (poste != 'A' && poste != 'P' && poste != 'O' && poste !=
'S');
/* Saisir et valider l'ancienneté, entre 1 et 25 ans */
do {
printf("Entrez l'anciennete entre %d et %d : ", MIN_ANC,
MAX_ANC);
scanf("%d", &anciennete);
/* un bon style de validation : à comprendre */
valide = anciennete >= MIN_ANC && anciennete <= MAX_ANC;
if (!valide)
printf("L'anciennete est en dehors de l'intervalle\n\n");
} while (!valide);
printf("\nLe poste saisi : %c, l'anciennete lue : %d\n",
poste, anciennete);
/* affichage utilisant le if imbriqué :
à titre d'exercice : faire une solution avec switch */
printf("Cet employe occupe le poste ");
if (poste == 'A')
printf("d'analyste");
else if (poste == 'P')
printf("de programmeur");
else if (poste == 'O')
printf("d'operateur");
else
printf("de secretaire");
printf("\n\nL'employe a %d annee(s) d'anciennetee\n\n", anciennete);
return 0 ;
}
Exécution
Entrez un caractere representant le poste de travail : v
Poste invalide, retapez S.V.P.
Entrez un caractere representant le poste de travail : a
Entrez l'anciennete entre 1 et 25: 89
L'anciennete est en dehors de l'intervalle
Entrez l'anciennete entre 1 et 25: -5
L'anciennete est en dehors de l'intervalle
Chapitre 3 : Boucles de répétition 66
Préparé par Le Van N. pour IFT 1810
Entrez l'anciennete entre 1 et 25: 12
Le poste saisi : A, l'anciennete lue : 12
Cet employe occupe le poste d'analyste
L'employe a 12 annee(s) d'anciennete
Exemple 3
/* Fichier dowhile3.c
Troisième application de la boucle do ... while
Faire certains calculs
Ce programme permet :
1. de calculer et d'afficher la somme = 1 + 2 + ... + 100
2. de comparer avec la formule : 1 + 2 + ... + n = n x (n+1) / 2
3. d'utiliser certaines écritures raccourcies pour obtenir la même
somme
*/
#include <stdio.h>
int main()
{
const int LIMITE = 100; /* calcul de 1 + 2 + 3 + ... + 100 */
int somme = 0, /* on initialise souvent une somme par 0 */
valeur = 1; /* première valeur à ajouter dans la somme
*/
/* avec do ... while */
do {
somme = somme + valeur;
valeur = valeur + 1;
} while (valeur <= LIMITE);
printf("La somme 1 + 2 + ... + %d = %d (avec do ... while)\n", LIMITE,
somme);
printf("\nLa meme somme avec la formule :\n");
printf(" 1 + 2 + ... + n = n x (n+1) / 2 : ");
printf("%d\n", LIMITE * (LIMITE+1) / 2 );
printf("\nLa meme somme avec l'ecriture raccourcie : ");
somme = 0;
valeur = 1;
do {
somme += valeur; /* <==> somme = somme + valeur ; */
valeur++; /* dans ce contexte :
valeur = valeur + 1;
ou valeur += 1;
ou valeur++; */
} while (valeur <= LIMITE);
printf("%d (meme valeur)\n", somme);
return 0 ;
}
Exécution
La somme 1 + 2 + ... + 100 = 5050 (avec do ... while)
Chapitre 3 : Boucles de répétition 67
Préparé par Le Van N. pour IFT 1810
La meme somme avec la formule :
1 + 2 + ... + n = n x (n+1) / 2 : 5050
La meme somme avec l'ecriture raccourcie : 5050 (meme valeur)
Exemple 4
/* Un autre exemple de do ... while
Jeu de "devin" :
L'ordinateur fournit un nombre aléatoire entre 1 et 1000.
L'usager du jeu a le droit à un maximum de 10 essais pour deviner
ce nombre caché.
On le guide dans le processus de la devinette en lui donnant des
messages pertinents.
*/
#include <stdio.h>
#include <stdlib.h> /* pour la fonction srand : rendre les valeurs
plus
aléatoirement possible si le paramètre n'est
pas
une constante. Dans l'exemple, on prend le
temps
courant comme paramètre */
#include <time.h> /* pour le temps courant */
#include <ctype.h> /* pour la fonction de conversion en majuscule */
int main()
{
const int BORNE = 1000, /* valeur cachée (à deviner) entre 1 et
BORNE */
MAX_ESSAIS = 10; /* nombre maximum d'essais */
int aDeviner, /* le nombre caché fourni par l'ordinateur à deviner
*/
nombre, /* le nombre fourni par l'usager du jeu */
nbEssai, /* compteur du nombre d'essais */
trouve; /* Oui ou Non on trouve le nombre caché */
char reponse; /* Oui ou Non l'usager veut continuer */
srand(time(NULL));
Chapitre 3 : Boucles de répétition 68
Préparé par Le Van N. pour IFT 1810
do {
/* rand() retourne un nombre aléatoire >= 0
rand() % BORNE donne un nombre aléatoire entre 0 et 999
rand % BORNE + 1 donne un nombre aléatoire entre 1 et 1000 */
aDeviner = rand() % BORNE + 1 ;
printf("On a un nombre cache entre 1 et %d, vous avez "
"le droit à un maximum %d essais\n", BORNE, MAX_ESSAIS);
printf("On y va!\n");
nbEssai = 0;
do {
/* saisir le nombre deviné par l'usager */
nbEssai++;
printf("Essai # %2d : quel est le nombre ? ", nbEssai);
scanf("%d", &nombre);
/* quand le nombre deviné est égal au nombre caché, on a
trouvé */
trouve = nombre == aDeviner;
if (trouve)
printf("Bravo, vous avez trouve le nombre cache %d apres %d
essai(s)\n",
aDeviner, nbEssai);
else if (nombre < aDeviner)
printf("%d est inferieur au nombre cache\n", nombre);
else
printf("%d est superieur au nombre cache\n", nombre);
} while (!trouve && nbEssai < MAX_ESSAIS);
/* après avoir fait 10 essais et non trouvé */
if (!trouve){
printf("\nLe nombre cache est : %d\n", aDeviner);
printf("Bonne chance a la prochaine fois\n");
}
printf("\n\nVoulez-vous jouer encore ? (o/n) ");
scanf(" %c", &reponse);
} while (toupper(reponse) == 'O');
return 0 ;
Chapitre 3 : Boucles de répétition 69
Préparé par Le Van N. pour IFT 1810
Exécution
On a un nombre cache entre 1 et 1000, vous avez le droit à un maximum
de 10 essais
On y va!
Essai # 1 : quel est le nombre ? 600
600 est superieur au nombre cache
Essai # 2 : quel est le nombre ? 500
500 est superieur au nombre cache
Essai # 3 : quel est le nombre ? 400
400 est superieur au nombre cache
Essai # 4 : quel est le nombre ? 300
300 est superieur au nombre cache
Essai # 5 : quel est le nombre ? 200
200 est inferieur au nombre cache
Essai # 6 : quel est le nombre ? 210
210 est inferieur au nombre cache
Essai # 7 : quel est le nombre ? 220
220 est inferieur au nombre cache
Essai # 8 : quel est le nombre ? 240
240 est inferieur au nombre cache
Essai # 9 : quel est le nombre ? 260
260 est superieur au nombre cache
Essai # 10 : quel est le nombre ? 250
250 est superieur au nombre cache
Le nombre cache est : 241
Bonne chance a la prochaine fois
Voulez-vous jouer encore ? (o/n) o
On a un nombre cache entre 1 et 1000, vous avez le droit à un maximum
10 essais
On y va!
Essai # 1 : quel est le nombre ? 500
500 est superieur au nombre cache
Essai # 2 : quel est le nombre ? 250
250 est inferieur au nombre cache
Essai # 3 : quel est le nombre ? 350
350 est inferieur au nombre cache
Essai # 4 : quel est le nombre ? 425
425 est superieur au nombre cache
Essai # 5 : quel est le nombre ? 370
370 est inferieur au nombre cache
Essai # 6 : quel est le nombre ? 400
400 est superieur au nombre cache
Essai # 7 : quel est le nombre ? 385
385 est inferieur au nombre cache
Essai # 8 : quel est le nombre ? 390
390 est superieur au nombre cache
Essai # 9 : quel est le nombre ? 387
Bravo, vous avez trouve le nombre cache 387 apres 9 essai(s)
Voulez-vous jouer encore ? (o/n) n
Chapitre 3 : Boucles de répétition 70
Préparé par Le Van N. pour IFT 1810
5) Simulation
Exemple 1
Soient j et k, deux variables déclarées de type int. Quelle est la valeur
affichée à l'écran par le segment de programme suivant?
int k = 1, j = 10;
do {
if (k >= 3)
j++;
else
j--;
k++;
printf("%3d%3d\n", j, k);
} while (j <10);
printf("%5d\n", j * k);
printf("FIN");
Solution :
(On utilise le symbole ^ pour représenter une espace)
j | k | Affichage à l'écran
-------------------------------------
10 | 1 |
9 | 2 | ^^9^^2
8 | 3 | ^^8^^3
9 | 4 | ^^9^^4
10 | 5 | ^10^^5
| | ^^^50
| | FIN
Exercice
Soient n et s, deux variables déclarées de type int. Quelle est la valeur
affichée à l'écran par la section de programme suivant?
int s = 0, n = 572;
do {
s = s + n % 10;
printf("%3d %3d\n", s, n);
n /= 10;
} while (n > 0);
printf("Fin");
Chapitre 3 : Boucles de répétition 71
Préparé par Le Van N. pour IFT 1810
B)Boucle while (condition) ... (Tant que ...)
1) Syntaxe
while (condition) faux
condition vrai
instruction;
instruction
L'instruction à répéter peut être simple (une seule action), structurée (une
autre instruction de contrôle) ou composée (c'est le cas le plus fréquent).
Exemples pour illustrer la syntaxe :
int somme = 0, int n = 1;
/* instruction à répéter est composée */
while ( n <= 10 ) {
somme += n;
n++;
}
printf("somme = 1 + 2 + 3 + ... + 10 = %d\n", somme);
int n = 5;
/* instruction à répéter est structurée */
while (n <= 10)
if (n == 10)
printf("Fin");
else
n++;
int n = 5;
/* instruction à répéter est simple */
while (n <= 10)
n++;
Chapitre 3 : Boucles de répétition 72
Préparé par Le Van N. pour IFT 1810
2) Fonctionnement
Étape 1 : vérifier d'abord la condition
Étape 2 : si la condition est vrai alors
on effectue l'instruction à répéter on revient à l'étape 1
sinon (la condition est faux),
on quitte la boucle
Conclusion :
Avec la boucle while …, il est possible, si la première évaluation est fausse,
de ne jamais exécuter l’instruction à répéter.
3) Domaines d'utilisation
On utilise la boucle while ... quand on ne sait pas à l'avance le nombre de fois
que l'on doit répéter le même traitement. On l'utilise surtout pour la lecture
d'un fichier, la recherche d'un élément dans un tableau, les calculs
scientifiques.
La lecture d'un fichier (non évaluée pour IFT 1810)
Supposons qu'on dispose du fichier nommé "entiers.dta" qui contient un
entier par ligne, par exemple :
65
-12
28
37
etc .
Écrire un programme permettant de lire le fichier, d'afficher son contenu, de
compter et d'afficher le nombre d'entiers lus dont la valeur est supérieure à
10.
Notes sur la lecture d'un fichier texte
Déclaration FILE *aLire;
Ouverture du fichier en mode de lecture aLire = fopen("entiers.dta","r");
Test pas fin de fichier while (!feof(aLire))
Lecture fscanf(aLire,...);
Fermeture fclose(aLire);
Chapitre 3 : Boucles de répétition 73
Préparé par Le Van N. pour IFT 1810
Solution
#include <stdio.h>
void main()
{
const int BORNE = 10;
int n, nbFois = 0;
FILE * aLire; /* déclaration du fichier */
/* Ouvrir le fichier en mode de lecture: "r" (de "reading") pour
lire */
aLire = fopen("entiers.dta", "r");
printf("Les entiers lus dans le fichier :\n\n");
/* La lecture, ligne par ligne */
while (!feof(aLire)){ /* Tant que pas fin du fichier
*/
fscanf(aLire, "%d\n", &n);
printf("%3d\n", n);
if (n > BORNE)
nbFois++;
}
/* Fermeture du fichier (fclose) */
fclose(aLire);
printf("Le nombre d'entiers supérieurs à %d est : %d\n", BORNE,
nbFois);
}
Exécution
Les entiers lus dans le fichier :
20
-12
15
-30
29
-50
40
Le nombre d'entiers supérieurs à 10 est : 4
Quelques exercices de calcul :
Exercice 1
Écrire un programme permettant de saisir et de valider un entier positif
(exemple 624). Le programme calcule et affiche à l'écran la somme des chiffres
qui forment l'entier lu (ici, la somme des chiffres est 12 soit le résultat de
l'addition de 6 + 2 + 4).
Chapitre 3 : Boucles de répétition 74
Préparé par Le Van N. pour IFT 1810
Solution
#include <stdio.h>
void main()
{
int n, valide, somChiffre;
/* saisir et valider n */
valide = 0; /* ce n'est pas valide */
while (!valide){
printf("Entrez un entier superieur a zero : ");
scanf("%d", &n);
valide = n > 0;
if (!valide)
printf("Valeur negative, retapez, S.V.P.\n\n");
}
printf("L'entier lu est %d\n", n);
printf("La somme des chiffres de %d est ", n);
/* Calcul de la somme des chiffres */
somChiffre = 0;
while (n){ /* c'est-à-dire while (n != 0), ici while (n > 0) */
somChiffre += n % 10; /* on ajoute le dernier chiffre n /= 10;
*/
}
printf("%3d\n", somChiffre);
}
Exécution
Entrez un entier superieur a zero : –5678
Valeur negative, retapez, S.V.P.
Entrez un entier superieur a zero : 8736
L'entier lu est 8736
La somme des chiffres de 8736 est 24
Exercice 2
Écrire un bloc d'instructions permettant de calculer et d'afficher la somme
suivante :
somme 1 1
3 1
5 1
7 1
999
Solution
const int BORNE1 = 1, BORNE2 = 999;
float denominateur = BORNE1, somme = 0;
while (denominateur <= BORNE2){
somme += 1 / denominateur;
denominateur += 2;
}
Chapitre 3 : Boucles de répétition 75
Préparé par Le Van N. pour IFT 1810
printf("La somme demandee : %10.6f\n", somme);
Exercice 3
Écrire un bloc d'instructions utilisant la boucle while qui permet d'estimer la
valeur de PI selon la formule suivante :
PI
4 1 13 15 17 19 19999
Au prochain chapitre, on revient sur la boucle while.
Autres exemples
Exemple 1
/* while1.c
Ce programme permet de calculer et d'afficher
la somme 1 + 1/3 + 1/5 + 1/7 + . . . + 1/49
en utilisant la boucle while
Exercices :
- refaire avec la boucle do ... while
- éventuellement, quand vous aurez vu la boucle for (voir plus
loin),
revenez ici à cet exemple pour le récrire mais avec la boucle
for
*/
#include <stdio.h>
void main()
{
/* déclarer les deux bornes et le pas entre les deux dénominateurs
*/
const int BORNE1 = 1,
BORNE2 = 49,
LE_PAS = 2;
float somme, denominateur;
/* calcul de la somme : 1 + 1/3 + 1/5 + 1/7 + ... + 1/49 */
somme = 0.0;
denominateur = BORNE1;
while (denominateur <= BORNE2){
somme += 1 / denominateur;
denominateur += LE_PAS;
}
printf("La somme de 1 + 1/2 + ... + 1/%d = %7.3f\n", BORNE2, somme);
}
Exécution
La somme de 1 + 1/2 + ... + 1/49 = 2.591
Chapitre 3 : Boucles de répétition 76
Préparé par Le Van N. pour IFT 1810
Exemple 2
/* while2.c
Ce programme permet de :
- calculer la somme des chiffres d'un nombre
- calculer l'envers d'un nombre
On affiche les informations nécessaires
Exercice : SIMULEZ les instructions pour comprendre
le fonctionnement de la boucle while
*/
#include <stdio.h>
void main()
{
int nombre = 573,
somChif,
envers;
printf("La somme des chiffres de %d ", nombre);
somChif = 0;
while (nombre > 0){
somChif += nombre % 10;
nombre /= 10;
}
printf("est %d\n\n", somChif);
nombre = 627;
printf("Le nombre %d a l'envers ", nombre);
envers = 0;
while (nombre > 0){
envers = envers * 10 + nombre % 10;
nombre /= 10;
}
printf("est %d\n\n", envers);
}
Exécution
La somme des chiffres de 573 est 15
Le nombre 627 a l'envers est 726
Chapitre 3 : Boucles de répétition 77
Préparé par Le Van N. pour IFT 1810
Exemple 3 (exercice de simulation pour préparer l'intra)
/* Fichier while3.c
Exercice de SIMULATION :
Simulez sur papier ce programme.
Exécutez le programme pour comparer avec vos simulations
*/
#include <stdio.h>
void main()
{
int a = 10, b = 10;
while (a == b){
printf("%3d%3d", a, b);
if (b % 2 == 0){
b = a * 3 % 9;
a = a - 7;
} else
b = b * ( a + 2);
}
printf("\n%3d%3d\n", a, b);
a = 10;
b = 10;
while (a = b){
printf("%3d%3d", a, b);
if (b % 2 == 0)
b = b - 10;
else
b = b - 5;
}
printf("\n%3d%3d\n", a, b);
}
Exécution
Résultat de simulation à comparer avec le vôtre
10 10 3 3
3 15
10 10
0 0
C) Boucle for ... :
1) Syntaxe
Chapitre 3 : Boucles de répétition 78
Préparé par Le Van N. pour IFT 1810
for (<expr. 1 initialisation>; <expr. condition de boucle>; <expr. de boucle>)
instruction
l'instruction à répéter peut être
simple, composée ou structurée.
l'expr. 1 initialisation est une
expression d'initialisation;
l'expr. 2 condition de boucle est
une expression logique, une
condition pour continuer la
répétition et celle-ci est évaluée
avant chaque itération de la
boucle;
l'expr. 3 de boucle est une
expression d'incrémentation ou de
décrémentation qui s'exécute à
chaque itération de la boucle.
Illustration de la syntaxe :
for (i = 1; i <= 10; i++)
printf("Bonsoir!\n");
Cette boucle fait afficher 10 lignes qui contient le message Bonsoir!
2) Fonctionnement
Initialiser la variable de contrôle de la boucle.
Tant que la condition pour continuer vaut vrai, faire :
exécuter l'instruction à répéter;
ajuster la valeur de la variable de contrôle (incrémenter ou
décrémenter).
Chapitre 3 : Boucles de répétition 79
Préparé par Le Van N. pour IFT 1810
3) Domaines d'utilisation
On utilise la boucle for quand on sait à l'avance le nombre de fois que l'on
répète le même traitement. C'est le cas des valeurs consécutives entre deux
bornes données. On l'utilise aussi fréquemment pour parcourir les indices
d'un tableau (les tableaux seront vus plus tard dans le cours).
Exemple 1
Écrire des blocs d'instructions qui permettent d'afficher :
6 7 8 9 10 11 ... 19 20
19 17 15 13 11 ... 3 1
ABCDEFGH....YZ
zy.... ba
Solution
#include <stdio.h>
void main()
{
int i;
char lettre;
/* afficher la première ligne : */
for (i = 5; i <= 20; i++)
printf("%3d", i);
printf("\n");
/* afficher la deuxième ligne : */
for (i = 19; i >= 1; i -= 2)
printf("%3d", i);
printf("\n");
/* afficher la troisième ligne : */
for (lettre = 'A'; lettre <= 'Z'; lettre++)
printf("%c", lettre);
printf("\n");
/* afficher la quatrième ligne : */
for (lettre = 'z'; lettre >= 'a'; lettre--)
printf("%c", lettre);
printf("\n");
}
Exécution
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
19 17 15 13 11 9 7 5 3 1
ABCDEFGHIJKLMNOPQRSTUVWXYZ
zyxwvutsrqponmlkjihgfedcba
Exemple 2
Chapitre 3 : Boucles de répétition 80
Préparé par Le Van N. pour IFT 1810
Écrire des blocs d'instructions qui permettent d'afficher :
12345
2345
345
45
5
12345
2 2
3 3
4 4
54321
Solution
#include <stdio.h>
void main()
{
int ligne, colonne;
for (ligne = 1; ligne <= 5; ligne++){
for (colonne = ligne; colonne <= 5; colonne++)
printf("%d", colonne);
printf("\n");
}
printf("\n");
for (colonne = 1; colonne <= 5; colonne++)
printf("%d", colonne);
printf("\n");
for (ligne = 2; ligne <= 4; ligne++)
printf("%d%4d\n", ligne, ligne);
for (colonne = 5; colonne >= 1; colonne--)
printf("%d", colonne);
printf("\n");
}
Exécution
12345
2345
345
45
5
12345
2 2
3 3
4 4
54321
Chapitre 3 : Boucles de répétition 81
Préparé par Le Van N. pour IFT 1810
Exemple 3
Écrire des blocs d'instructions qui permettent de :
calculer et afficher la somme suivante :
s = 5 + 6 + 7 + ... + 49
d'estimer la valeur de PI sachant que :
4 1 3 5 7 9 29999
PI 1 1 1 1 1
Solution
#include <stdio.h>
void main()
{
const int BORNE1 = 5,
BORNE2 = 49;
const int MAX_DENO = 29999, LE_PAS = 2;
int somme, terme, denominateur;
float signe, piSur4;
/* Calcul de s = 5 + 6 + ... + 49 */
somme = 0;
for (terme = BORNE1; terme <= BORNE2; terme++)
somme += terme;
printf("\nsomme = %3d\n", somme);
/* Estimation de PI sachant que PI/4 = 1 - 1/3 + ... - 1/29999 */
piSur4 = 0;
signe = +1.0;
for (denominateur = 1; denominateur <= MAX_DENO; denominateur +=
LE_PAS){
piSur4 += signe / denominateur;
signe = -signe;
}
printf("\nValeur estimée de PI = %8.6f\n", 4 * piSur4);
}
Exécution
somme = 1215
Valeur estimée de PI = 3.141533
Chapitre 3 : Boucles de répétition 82
Préparé par Le Van N. pour IFT 1810
Exemple 4
Le nombre 720 a 30 diviseurs (1, 2, 3, 4, 5, 6, 8, 9, ..., 360, 720). Un autre
nombre, supérieur à 720 mais inférieur à 1000, en a encore plus.
Écrire un programme qui permet de découvrir ce nombre et d'afficher ses
diviseurs à raison de 5 diviseurs par ligne.
Solution
#include <stdio.h>
void main()
{
const int MINI = 720,
MAXI = 1000,
A_BATTRE = 30,
PAR_LIGNE = 5;
int nombre,
nbDiv,
k,
n;
/* examiner nombre par nombre entre 721 et 999 */
for (nombre = MINI + 1; nombre < MAXI; nombre++){
/* compter le nombre de diviseurs du nombre examiné */
nbDiv = 2; /* 1 et le nombre lui-même sont 2 diviseurs */
for (k = 2; k <= nombre / 2; k++)
if (nombre % k == 0)
nbDiv++;
/* vérifier si c'est un nombre à découvrir */
if (nbDiv > A_BATTRE){
printf("Le nombre %d a %d diviseurs\n", nombre, nbDiv);
printf("\nEn voici la liste:\n");
n = 0;
for (k = 1; k <= nombre; k++)
if (nombre % k == 0){
n++;
printf("%4d) %5d", n, k);
if (n % PAR_LIGNE == 0)
printf("\n");
}
}
} /* fin du for */
} /* fin du main */
Chapitre 3 : Boucles de répétition 83
Préparé par Le Van N. pour IFT 1810
Exécution
Le nombre 840 a 32 diviseurs
En voici la liste:
1) 1 2) 2 3) 3 4) 4 5) 5
6) 6 7) 7 8) 8 9) 10 10) 12
11) 14 12) 15 13) 20 14) 21 15) 24
16) 28 17) 30 18) 35 19) 40 20) 42
21) 56 22) 60 23) 70 24) 84 25) 105
26) 120 27) 140 28) 168 29) 210 30) 280
31) 420 32) 840
Exemple 5
Écrire un programme qui permet de :
saisir et valider le nombre total de pattes de poules (à 2 pattes) et de
vaches (à 4 pattes);
afficher toutes les solutions possibles du nombre de poules et de
vaches.
Solution
#include <stdio.h>
void main()
{
int nbPattes, nbPoules, nbVaches, valide;
do{
printf("\nEntrez un nombre pair pour le nombre total de pattes
: ");
scanf("%d", &nbPattes);
valide = nbPattes > 0 && nbPattes % 2 == 0;
if (!valide)
if (nbPattes <= 0)
printf("Un nombre positif S.V.P.");
else
printf("Un nombre pair S.V.P.");
} while (!valide);
printf("\n\n");
nbPoules = nbPattes / 2;
for (nbVaches = 0; nbVaches <= nbPattes / 4; nbVaches++){
printf("%2d vache(s) et %2d poule(s)\n", nbVaches, nbPoules);
nbPoules -= 2;
}
}
Chapitre 3 : Boucles de répétition 84
Préparé par Le Van N. pour IFT 1810
Exécution
Entrez un nombre pair pour le nombre total de pattes : –52
Un nombre positif S.V.P.
Entrez un nombre pair pour le nombre total de pattes : 21
Un nombre pair S.V.P.
Entrez un nombre pair pour le nombre total de pattes : 22
0 vache(s) et 11 poule(s)
1 vache(s) et 9 poule(s)
2 vache(s) et 7 poule(s)
3 vache(s) et 5 poule(s)
4 vache(s) et 3 poule(s)
5 vache(s) et 1 poule(s)
Exercice 1
Écrire un bloc d'instructions permettant d'afficher les 20 consonnes en
minuscules à l'écran.
Solution
char lettre ;
for (lettre = 'a'; lettre <= 'z'; lettre++)
if (lettre != 'a' && lettre != 'e' && lettre != 'i' &&
lettre != 'o' && lettre != 'u' && lettre != 'y')
printf("%c", lettre);
printf("\n");
Exercice 2
Réaliser une autre solution de l'exercice 1 en remplaçant le if par un switch.
Exercice 3
Écrire un bloc d'instructions permettant de calculer et d'afficher la somme
suivante :
somme 1 1 2 1 3 11000
Solution
const int BORNE1 = 1,
BORNE2 = 1000;
int denominateur;
float somme = 0;
for (denominateur = BORNE1; denominateur <= BORNE2; denominateur++)
somme += 1.0 / denominateur;
printf("La somme demandée : %10.6f\n", somme);
Chapitre 3 : Boucles de répétition 85
Préparé par Le Van N. pour IFT 1810
Exercice 4
Écrire un bloc d'instructions utilisant la boucle for qui permet d'estimer la valeur
de PI selon la formule suivante :
PI
4 1 13 15 17 19 19999
Solution
const int LIMITE = 9999;
float piSur4 = 0.0, signe = 1.0;
int denominateur;
for ( denominateur = 1; denominateur <= LIMITE / 2; denominateur += 2){
piSur4 += signe / denominateur;
signe = -signe;
}
printf("La valeur estimée de PI est %12.6f ",4 * piSur4);
On reviendra sur la boucle "for" lorsqu'on abordera la notion des tableaux un peu
plus loin dans le cours.
Autres exemples
Exemple 1
/* Fichier for1.c (1er exemple de la boucle for)
*
* 1) afficher 10 fois Bonsoir
* traitement commun : afficher Bonsoir
* nombre de fois connu à l'avance : 10 fois
* => bon candidat pour la boucle for
*
* 2) calculer + afficher la somme
* s = 3 + 5 + 7 + ... + 51
* on connaît :
* - la valeur de départ : 3
* - la valeur d'arrivée : 51
* - le pas entre 2 valeurs est une constante
* (ici le pas vaut 2)
* => bon candidat pour la boucle for
*
* Révision : recalculer avec do ... while, while ....
*/
Chapitre 3 : Boucles de répétition 86
Préparé par Le Van N. pour IFT 1810
#include <stdio.h>
void main()
{
#define NB_FOIS 10
#define BORNE1 3
#define BORNE2 51
#define LE_PAS 2
int i, /* pour la boucle for */
somme, /* pour somme = 3 + 5 + ... + 51 */
valeur; /* somme des valeurs */
/* afficher 10 fois Bonsoir */
for (i = 1; i <= NB_FOIS; i++)
printf("Bonsoir\n");
printf("\n\nLa somme de %d + %d + ... + %d\n" , BORNE1,
BORNE1 + LE_PAS,
BORNE2);
/* calculer s = 3 + 5 + ... + 51 avec for . . .*/
somme = 0;
for (valeur = BORNE1; valeur <= BORNE2; valeur += LE_PAS)
somme += valeur;
printf("Avec la boucle for . . . . . . %d\n", somme);
/* calculer s = 3 + 5 + ... + 51 avec do ... while . . .*/
somme = 0;
valeur = BORNE1;
do{
somme += valeur;
valeur += LE_PAS;
}while (valeur <= BORNE2);
printf("Avec la boucle do ... while ... %d\n", somme);
/* calculer s = 3 + 5 + ... + 51 avec while . . .*/
somme = 0;
valeur = BORNE1;
while (valeur <= BORNE2){
somme += valeur;
valeur += LE_PAS;
}
printf("Avec la boucle while .......... %d\n", somme);
}
Chapitre 3 : Boucles de répétition 87
Préparé par Le Van N. pour IFT 1810
Exécution
Bonsoir
Bonsoir
Bonsoir
Bonsoir
Bonsoir
Bonsoir
Bonsoir
Bonsoir
Bonsoir
Bonsoir
La somme de 3 + 5 + ... + 51
Avec la boucle for . . . . . . 675
Avec la boucle do ... while ... 675
Avec la boucle while .......... 675
Exemple 2
#include <stdio.h>
/* for2.c
Dans cet exemple, on se concentre sur l'essentiel et on vous
laisse le soin de déclarer des constantes pour les bornes,
les pas, ici ce n'est pas l'objectif de l'exemple.
But : utiliser la boucle for
*/
void main()
{
int n, k ;
char c ;
/* afficher 5 7 9 11 13 15 ... 25 sur la même ligne */
for (n = 5; n <= 25; n+= 2)
printf("%3d", n);
printf("\n");
/* afficher 100 95 90 85 . . . 70 sur la même ligne */
for (n = 100; n >= 70; n -= 5)
printf("%3d", n);
printf("\n");
/* afficher les 26 lettres MAJUSCULES sur la même ligne */
for (c = 'A'; c <= 'Z'; c++)
printf("%c", c);
printf("\n");
Chapitre 3 : Boucles de répétition 88
Préparé par Le Van N. pour IFT 1810
/* afficher les 20 consonnes MAJUSCULES sur la même ligne */
for (c = 'A'; c <= 'Z'; c++)
switch (c){
case 'A':
case 'E':
case 'I':
case 'O':
case 'U':
case 'Y': break ;
default : printf("%c", c);
}
printf("\n");
/* afficher les diviseurs de 20 */
printf("\n\nLes diviseurs de 20 sont : ");
for (n = 1; n <= 20; n++)
if (20 % n == 0)
printf("%3d", n);
printf("\n");
/* afficher la table des multiplications de 1 à 10 : */
printf("\n\nLa table des multiplications de 1 a 10 :\n");
printf(" ");
for (n = 1; n <= 10; n++)
printf("%4d", n);
printf("\n");
for (n = 1 ; n <= 10 ; n++){
printf("%4d", n);
for (k = 1; k <= 10; k++)
printf("%4d", n * k);
printf("\n");
}
}
Exécution
5 7 9 11 13 15 17 19 21 23 25
100 95 90 85 80 75 70
ABCDEFGHIJKLMNOPQRSTUVWXYZ
BCDFGHJKLMNPQRSTVWXZ
Les diviseurs de 20 sont : 1 2 4 5 10 20
Chapitre 3 : Boucles de répétition 89
Préparé par Le Van N. pour IFT 1810
La table des multiplications de 1 a 10 :
1 2 3 4 5 6 7 8 9 10
1 1 2 3 4 5 6 7 8 9 10
2 2 4 6 8 10 12 14 16 18 20
3 3 6 9 12 15 18 21 24 27 30
4 4 8 12 16 20 24 28 32 36 40
5 5 10 15 20 25 30 35 40 45 50
6 6 12 18 24 30 36 42 48 54 60
7 7 14 21 28 35 42 49 56 63 70
8 8 16 24 32 40 48 56 64 72 80
9 9 18 27 36 45 54 63 72 81 90
10 10 20 30 40 50 60 70 80 90 100
Exemple 3
/* Fichier for3.c (3ième exemple de la boucle for)
*
* 1) déterminer et afficher les diviseurs de 6
*
* 2) déterminer et afficher les diviseurs de 720
*
* Exercices de révision : refaire avec
* a) do ... while
* b) while ....
*/
#include <stdio.h>
void main ()
{
const int NOMBRE1 = 6,
NOMBRE2 = 720;
int nombre, /* le nombre est-il un diviseur de ... */
nbDivi; /* compteur du nombre de diviseurs */
/* compter le nombre de diviseurs de 6 */
nbDivi = 0; /* initialiser le compteur */
printf("Les diviseurs de %d sont :\n", NOMBRE1);
/* on examine tous les nombres entre 1 et 6 */
for (nombre = 1; nombre <= NOMBRE1; nombre++)
if (NOMBRE1 % nombre == 0){ /* si nombre est un diviseur de
NOMBRE1 */
nbDivi++; /* on incrémente le compteur */
printf("%3d) %5d\n", nbDivi, nombre);
}
/* affichage : */
printf("Le nombre %d a %d diviseurs\n", NOMBRE1, nbDivi);
Chapitre 3 : Boucles de répétition 90
Préparé par Le Van N. pour IFT 1810
/* compter le nombre de diviseurs de 720 */
nbDivi = 0; /* initialiser le compteur */
printf("\nLes diviseurs de %d sont :\n", NOMBRE2);
/* on examine tous les nombres entre 1 et 720 */
for (nombre = 1; nombre <= NOMBRE2; nombre++)
if (NOMBRE2 % nombre == 0) /* si nombre est un diviseur de
NOMBRE2 */
printf("%3d) %5d\n", ++nbDivi, nombre);
/* affichage : */
printf("Le nombre %d a %d diviseurs\n\n", NOMBRE2, nbDivi);
}
Exécution
Les diviseurs de 6 sont :
1) 1
2) 2
3) 3
4) 6
Le nombre 6 a 4 diviseurs
Les diviseurs de 720 sont :
1) 1
2) 2
3) 3
4) 4
5) 5
6) 6
7) 8
8) 9
9) 10
10) 12
11) 15
12) 16
13) 18
14) 20
15) 24
16) 30
17) 36
18) 40
19) 45
20) 48
21) 60
22) 72
23) 80
24) 90
25) 120
26) 144
27) 180
28) 240
29) 360
30) 720
Chapitre 3 : Boucles de répétition 91
Préparé par Le Van N. pour IFT 1810
Le nombre 720 a 30 diviseurs
Exemple 4
/* Fichier for4.c (4ième exemple de la boucle for)
* "for imbriqué" : for dans un autre for
* Afficher :
* 1 2 3 4 5
* 2 3 4 5
* 3 4 5
* 4 5
* 5
* Simulez un bloc avec for imbriqué
*
* Exercice : Écrivez un bloc avec for imbriqué pour
* afficher :
* 1
* 1 2
* 1 2 3
* 1 2 3 4
* 1 2 3 4 5
*/
#include <stdio.h>
void main ()
{
const int BORNE = 5;
int ligne, col; /* ligne, colonne */
/* simuler cet extrait de code pour mieux assimiler */
/* de la ligne 1 à la ligne 5 */
for (ligne = 1; ligne <= BORNE; ligne++){
/* pour colonne varie de numéro de ligne jusqu'à 5 */
for (col = ligne; col <= BORNE; col++)
printf("%2d", col); /* afficher la valeur de la colonne */
printf("\n");
}
printf("\n\n");
/* À simuler pour comprendre cet extrait de code : */
/* de la ligne 1 à la ligne 5 */
for (ligne = 1; ligne <= BORNE; ligne++){
for (col = 1; col <= ligne + 2; col++)
switch (col){
case 1 :
case 3 : printf("%3d", col);
break;
case 6 : printf("%3d", ligne+col);
break;
default: printf("%3d", 2*col);
}
printf("\n");
}
}
Chapitre 3 : Boucles de répétition 92
Préparé par Le Van N. pour IFT 1810
Exécution
1 2 3 4 5
2 3 4 5
3 4 5
4 5
5
1 4 3
1 4 3 8
1 4 3 8 10
1 4 3 8 10 10
1 4 3 8 10 11 14
Exemple 5
/* Autre application de do ... while
valider les (valeurs des) données
*/
#include <stdio.h>
#include <ctype.h>
void main()
{
const int MIN_ANC = 1,
MAX_ANC = 25;
char poste; /* parmi : A, P, O et S analyste, programmeur,
opérateur, secrétaire */
int anciennete; /* nb. d'années d'ancienneté */
int valide; /* Oui ou Non l'ancienneté est valide */
/* Saisir et valider le poste de travail */
do{
printf("Entrez un caractere representant le poste de travail :
");
fflush(stdin);
/* lire et convertir le caractère lu en MAJUSCULE */
poste = toupper(getchar());
if (poste != 'A' && poste != 'P' && poste != 'O' && poste != 'S')
printf("poste invalide, retapez S.V.P.\n\n");
}while (poste != 'A' && poste != 'P' && poste != 'O' && poste !=
'S');
Chapitre 3 : Boucles de répétition 93
Préparé par Le Van N. pour IFT 1810
/* Saisir et valider l'anciennetée, entre 1 et 25 ans */
do{
printf("Entrez l'anciennete entre %d et %d : ", MIN_ANC,
MAX_ANC);
scanf("%d", &anciennete);
valide = anciennete >= MIN_ANC && anciennete <= MAX_ANC;
if (!valide)
printf("L'anciennete est en dehors de l'intervalle\n\n");
} while (!valide);
printf("\nLe poste saisi : %c, l'anciennete lue : %d\n",
poste, anciennete);
/* affichage utilisant le if imbriqué : */
printf("L'employe occupe un poste ");
if (poste == 'A')
printf("d'analyste ");
else if (poste == 'P')
printf("de programmeur ");
else if (poste == 'O')
printf("d'operateur ");
else
printf("de secretaire ");
printf("\n\nL'employe a %d annee(s) d'anciennete\n\n", anciennete);
}
Exécution
Entrez un caractere representant le poste de travail : z
poste invalide, retapez S.V.P.
Entrez un caractere representant le poste de travail : a
Entrez l'anciennete entre 1 et 25 : 56
L'anciennete est en dehors de l'intervalle
Entrez l'anciennete entre 1 et 25 : -7
L'anciennete est en dehors de l'intervalle
Entrez l'anciennete entre 1 et 25 : 12
Le poste saisi : A, l'anciennetee lue : 12
L'employe occupe un poste d'analyste
L'employe a 12 annee(s) d'anciennetee
Chapitre 3 : Boucles de répétition 94
Préparé par Le Van N. pour IFT 1810