Aller au contenu

1.3 Boucle While⚓︎

1. Premiers exemples⚓︎

À la différence essentielle des boucles for, dont on peut savoir à l'avance combien de fois elles vont être exécutées, les boucles while sont des boucles dont on ne sort que lorsqu'une condition n'est plus satisfaite.

Avec donc le risque de rester infiniment bloqué à l'intérieur !

image

Exemple fondateur n°1 ❤

Le programme suivant :

1
2
3
4
5
a = 0
while a < 3:
    print("ok")
    a = a + 1
print("fini")
va donner ceci :
ok
ok
ok
fini

Analyse grâce à PythonTutor

Question

le code ci-dessous va-t-il donner un résultat différent ?

1
2
3
4
5
a = 0
while a < 3:
    a = a + 1
    print("ok")
print("fini")

Résultat du programme ⏬
ok
ok
ok
fini

Conclusion : l'évaluation de la condition ne se fait pas à chaque ligne mais bien au début de chaque tour de boucle. Si la variable qui déclenchera la sortie de boucle atteint sa valeur de sortie au milieu des instructions, les lignes restantes sont quand même exécutées.

2. Syntaxe générale⚓︎

Écriture d'une boucle while

while condition:
    instruction1
    instruction2
        ...
    instructionN

2.1 La condition⚓︎

La condition est un booléen, c'est-à-dire une expression que Python évaluera à True ou à False.

Prenons une variable a égale à 10.

>>> a = 10
>>> a
10

Voici différents tests sur cette variable a. Chacun de ces tests va donner un booléen, qui sera égal à True ou à False.

La syntaxe de ces tests est à connaître par cœur.

>>> a > 8
True
>>> a > 12
False
>>> a == 10
True
>>> a != 7
True
>>> a != 10
False
>>> a >= 10
True

Un cours sur les booléens aura lieu ici.

2.2 Les instructions⚓︎

Les instructions instruction1 jusqu'à instructionN sont exécutées dans cet ordre à chaque tour de boucle.

⚠ Attention : ces instructions doivent obligatoirement avoir un impact sur la condition évaluée après le while(dans le cours sur la dichotomie, nous évoquerons la notion de variant de boucle).

Voir le piège n°1 ...

3. Les pièges ...⚓︎

3.1 piège n°1 : ne JAMAIS SORTIR de la boucle⚓︎

Exemple fondateur n°2 ❤

Le programme suivant :

1
2
3
4
5
6
a = 0
while a < 3:
    print("ok")
    a = a + 1
    a = a * 0
print("ce texte ne s'écrira jamais")
va écrire une suite infinie de ok et ne jamais s'arrêter

3.2 piège n°2 : ne JAMAIS ENTRER dans la boucle⚓︎

Exemple fondateur n°3 ❤

Le programme suivant :

1
2
3
4
5
6
a = 0
while a > 10:
    print("ce texte non plus ne s'écrira jamais")
    a = a + 1

print("fini") 

va écrire fini et s'arrêter.

Exercice 1

Trouver le plus petit nombre entier \(n\) tel que \(2^n\) soit supérieur à 1 milliard.

Correction
1
2
3
4
n = 1
while 2**n < 10**9:
    n = n + 1
print('trouvé : ',n)

4. Quelques remarques⚓︎

4.1 Lien entre while et for⚓︎

image

La boucle bornée for que nous avons étudiée est très pratique.

Mais nous pourrions nous en passer : toutes les boucles for peuvent en fait être ré-écrites en utilisant while. (alors que la réciproque est fausse)

Exercice 2

On considère le code ci-dessous :

1
2
for k in range(5):
    print("scooby-doo")
Ré-écrire ce code en utilisant une boucle while.

Correction
1
2
3
4
k = 0
while k < 5:
    print('scooby-doo')
    k = k + 1

4.2 Les boucles infinies volontaires⚓︎

image

La boucle infinie a été présentée comme un danger qu'il faut éviter.

Pourtant, dans quelques situations, il est d'usage d'enfermer volontairement l'utilisateur dans une boucle infinie.

Observez et exécutez le code suivant :

1
2
3
4
5
6
while True:
    reponse = input("tapez sur la lettre S du clavier pour me sortir de cet enfer : ")
    if reponse == 's':
        break

print("merci, j'étais bloqué dans une boucle infinie")
  • le début du code : while True est typique des boucles infinies volontaires. On aurait tout aussi bien pu écrire while 3 > 2 (on rencontre même parfois des while 1)
  • vous avez découvert l'expression break qui comme son nom l'indique permet de casser la boucle (cela marche pour while comme pour for) et donc d'en sortir. Son emploi est controversé parmi les puristes de la programmation. Nous dirons juste que c'est une instruction bien pratique.

Exercice 3

Reprendre l'exemple précédent en faisant deviner un mot de passe (préalablement stocké dans une variable).

Correction
1
2
3
4
5
6
7
mdp = 'supermotdepasse'

while True:
    rep = input('mot de passe ?')
    if rep == mdp:
        break
print('accès autorisé')

mieux :

1
2
3
4
5
6
7
8
import hashlib
hsh = '696cebb8f23e45f3c3d8e6582bc1a8182abc0119ed3dd89b7de069a9ea8957ab'

while True:
    rep = input("mot de passe ")
    if hashlib.sha256(rep.encode("utf-8")).hexdigest() == hsh:
        break
print("accès autorisé")