Chapitre 3 — Les conditions et les tests logiques

Dans un algorithme, il est souvent nécessaire de prendre une décision : faire une action seulement si une certaine situation est vraie. Les conditions permettent justement de donner cette capacité de réflexion à l’algorithme. C’est ce qui transforme une suite d’instructions en un véritable raisonnement logique.
Objectifs pédagogiques
  • Comprendre la notion de condition et de test logique.
  • Savoir formuler une instruction conditionnelle (si… alors… sinon).
  • Être capable de combiner plusieurs conditions avec les opérateurs logiques.
  • Apprendre à représenter un choix dans un algorithme.
Plan du chapitre
  • 1. Pourquoi utiliser des conditions ?
  • 2. L’instruction SI…ALORS…SINON
  • 3. Les opérateurs logiques
  • 4. Les conditions imbriquées et multiples
  • 5. Applications directes

Pourquoi utiliser des conditions ?

Définition
Une condition est une expression logique qui peut être Vraie ou Fausse. Elle permet à l’algorithme de choisir entre plusieurs chemins d’exécution.

On peut comparer une condition à un feu de signalisation :
si le feu est vert, on avance ; s’il est rouge, on s’arrête.
De même, un algorithme exécute certaines instructions seulement si la condition est remplie.

Exemple
Début
    Lire âge
    Si âge >= 18 Alors
        Écrire "Tu es majeur."
    FinSi
Fin

L’algorithme vérifie si l’âge est supérieur ou égal à 18.
Si c’est le cas, il affiche un message. Sinon, il ne fait rien.

L’instruction SI…ALORS…SINON

Définition
L’instruction conditionnelle permet d’exécuter une partie du code seulement si la condition est vraie.
Elle offre à l’algorithme la possibilité de prendre une décision.
On l’écrit généralement ainsi :
Si condition Alors
    instructions à exécuter si la condition est vraie
Sinon
    instructions à exécuter sinon
FinSi

Cette structure est appelée conditionnelle car elle dépend d’un test : l’algorithme vérifie une condition avant d’agir. Si la condition est vraie, il exécute la première partie ; sinon, il passe à la seconde.

Exemple
Début
    Lire température
    Si température \leq 0 Alors
        Écrire "Il gèle !"
    Sinon
        Écrire "La température est positive."
    FinSi
Fin

Ici, la variable température est évaluée. Si sa valeur est inférieure à 0, l’algorithme affiche « Il gèle ! ». Sinon, il affiche « La température est positive. »

Ce type de structure est appelé test binaire, car il n’existe que deux chemins possibles : un chemin pour la condition vraie, un autre pour la condition fausse.

L’instruction conditionnelle est donc une bifurcation : c’est comme un croisement sur une route. Selon la situation, l’algorithme choisit de tourner à gauche ou à droite, mais jamais les deux à la fois.

Astuce
Vous pouvez omettre le Sinon si vous n’avez rien à faire lorsque la condition est fausse. Dans ce cas, l’algorithme se contente d’exécuter la partie « Alors » lorsque la condition est vraie.
Exemple sans “Sinon”
Début
    Lire température
    Si température \leq 0 Alors
        Écrire "Attention, il gèle !"
    FinSi
    Écrire "Programme terminé."
Fin

Dans cet exemple, l’algorithme affiche un message supplémentaire uniquement si la condition est vraie. Si la température est de 10, aucune alerte n’est affichée, mais le programme continue normalement.

Cette manière de faire est très fréquente, car de nombreux cas ne nécessitent pas d’alternative spécifique. Elle simplifie la lecture et évite les branches inutiles.

Enfin, il est important de remarquer que la condition évaluée doit toujours être une expression logique. Autrement dit, elle doit pouvoir être vraie ou fausse. Par exemple :

Si âge >= 18 Alors
    Écrire "Majeur"
Sinon
    Écrire "Mineur"
FinSi

Ici, le test âge >= 18 est une expression logique : il renvoie Vrai si l’âge est supérieur ou égal à 18, et Faux sinon. C’est ce résultat qui décide du chemin pris par l’algorithme.

Les opérateurs logiques

Définition
Les opérateurs logiques permettent de combiner plusieurs conditions pour former des tests plus précis. Ils retournent une valeur booléenne (Vrai ou Faux).

Parfois, une seule condition ne suffit pas à décrire une situation réelle.
On veut par exemple tester si un nombre est dans un intervalle, ou si un élève a réussi ou est en rattrapage.
C’est là qu’interviennent les opérateurs logiques, qui permettent de relier plusieurs tests entre eux.

OpérateurSignificationExempleRésultat
etLes deux conditions doivent être vraiesx > 0 et x \leq 10Vrai si x est compris entre 0 et 10
ouAu moins une des deux conditions est vraiex \leq 0 ou x > 100Vrai si x est en dehors de l’intervalle
nonInverse le résultat de la conditionnon(x > 5)Vrai si x ≤ 5

Ces opérateurs permettent d’exprimer des raisonnements logiques :

Exemple
Début
    Lire note
    Si note >= 10 et note \leq 12 Alors
        Écrire "Passable"
    Si note >= 12 et note \leq 16 Alors
        Écrire "Assez bien"
    Si note >= 16 Alors
        Écrire "Très bien"
Fin

Dans cet algorithme, chaque condition décrit un intervalle précis de valeurs pour note. Si la note est de 11, seule la première condition sera vraie ; si elle vaut 14, seule la deuxième s’applique ; et ainsi de suite. Cela montre que l’algorithme choisit dynamiquement le bon chemin en fonction des valeurs fournies.

Les opérateurs logiques permettent donc de rendre les tests plus expressifs, en rapprochant le raisonnement du langage naturel.

Astuce
Pour vérifier si une valeur est comprise entre deux bornes, on peut combiner deux conditions avec et. Par exemple : Si âge >= 13 et âge \leq 17 signifie « si l’âge est compris entre 13 et 17 ans inclus ». C’est une manière simple d’écrire des intervalles sans multiplier les Si.
Erreur fréquente
Écrire plusieurs conditions contradictoires peut rendre l’algorithme incohérent.
Par exemple, Si x > 10 et x \leq 5 ne sera jamais vrai.
De même, mal utiliser ou peut produire des résultats inattendus.
Par exemple, Si x \leq 0 ou x > 100 est vrai pour presque tous les nombres sauf ceux compris entre 0 et 100.
Il faut donc toujours bien formuler la logique du test avant de l’écrire.

Les opérateurs logiques sont à la base de tout raisonnement informatique. Ils permettent à un programme de poser des questions complexes, d’analyser plusieurs situations à la fois et d’adapter son comportement selon les réponses obtenues.

Les conditions imbriquées et multiples

Définition
Les conditions peuvent être imbriquées (une dans une autre) ou multiples (enchaînées). Cela permet de gérer plusieurs cas possibles dans un même algorithme.

Exemple de condition imbriquée

Début
    Lire âge
    Si âge >= 18 Alors
        Lire permis
        Si permis = "oui" Alors
            Écrire "Tu peux conduire."
        Sinon
            Écrire "Tu es majeur mais sans permis."
        FinSi
    Sinon
        Écrire "Tu es mineur."
    FinSi
Fin

L’algorithme pose d’abord une question (âge), puis une autre (permis) seulement si la première condition est remplie. C’est un raisonnement hiérarchique.

Exemple de condition multiple

Si note >= 16 Alors
    Écrire "Très bien"
SinonSi note >= 12 Alors
    Écrire "Assez bien"
SinonSi note >= 10 Alors
    Écrire "Passable"
Sinon
    Écrire "Insuffisant"
FinSi

Ici, une seule condition est vraie à la fois. Dès qu’une branche est exécutée, les autres sont ignorées.

Applications directes

Les conditions permettent à un algorithme de s’adapter à des situations variées.
Dans les exemples suivants, vous verrez comment elles peuvent être utilisées pour faire des choix logiques selon les valeurs saisies par l’utilisateur.

Exercice 1 :
Écrire un algorithme qui lit un nombre et affiche s’il est positif, négatif ou nul.

Début
    Lire n
    Si n > 0 Alors
        Écrire "Positif"
    SinonSi n \leq 0 Alors
        Écrire "Négatif"
    Sinon
        Écrire "Nul"
    FinSi
Fin

Entrée : -7
Sortie : Négatif

Cet algorithme commence par lire un nombre. Il teste ensuite trois cas possibles :

Ce type de structure est très courant : il permet de distinguer clairement des situations exclusives, c’est-à-dire des cas qui ne peuvent pas être vrais en même temps.

Pour s’en souvenir, on peut imaginer une balance :

Ainsi, l’algorithme agit comme une balance logique, déterminant de quel côté penche le nombre.

Exercice 2 : Écrire un algorithme qui lit l’âge d’une personne et affiche un tarif selon sa catégorie.

Début
    Lire âge
    Si âge \leq 12 Alors
        Écrire "Tarif enfant"
    SinonSi âge \leq 26 Alors
        Écrire "Tarif jeune"
    SinonSi âge >= 65 Alors
        Écrire "Tarif senior"
    Sinon
        Écrire "Tarif plein"
    FinSi
Fin

Entrée : 20
Sortie : Tarif jeune

Cet algorithme lit l’âge et choisit la catégorie tarifaire correspondante :

Le principe repose sur un enchaînement de conditions évaluées dans l’ordre. Dès qu’une condition est vraie, l’algorithme exécute l’instruction correspondante et ignore les suivantes.

Cela reproduit le raisonnement humain : « Si la personne est un enfant, je lui applique le tarif enfant. Sinon, si c’est un jeune, je lui applique le tarif jeune. Sinon, si c’est un senior, je lui applique le tarif senior. Sinon, c’est un adulte et je lui donne le tarif plein. »

À retenir
  • Une condition est une question à laquelle l’ordinateur répond par Vrai ou Faux.
  • L’instruction Si…Alors…Sinon permet de créer un choix dans l’algorithme.
  • Les opérateurs logiques permettent de combiner ou de nier plusieurs conditions.
  • Grâce aux tests, un programme peut adapter son comportement à la situation.
Prochain chapitre
Dans le prochain chapitre, vous apprendrez à utiliser les boucles pour répéter une série d’instructions plusieurs fois.