Chapitre 1 - Introduction à Lalgorithmique

Télécharger au format pdf ou txt
Télécharger au format pdf ou txt
Vous êtes sur la page 1sur 26

12/04/2022

Département d‘Informatique
Filière: SMIA
A.U: 2021-2022

Cours: Algorithmique I

Badraddine AGHOUTANE

1 Introduction à l’informatique
2 Introduction à la programmation

3 Algorithmique: Outils de base

4 Structures d’un algorithme


5 Instructions conditionnelles et alternatives
6 Instructions répétitives (les boucles)

7 Les chaines de caractères

8 Les variables dimensionnés ( les tableaux)

1
12/04/2022

Introduction à l’informatique
Qu’est ce que l’informatique ?
Mot inventé par P. Computer Science
Dreyfus en 1962 INFORMATIQUE ? en anglais

INFORMATION AUTOMATIQUE
Science de l’information Art d’exécuter automatiquement des actions

Traitement automatique de l’information

Machine automatique ORDINATEUR

L’informatique est la science de traitement automatique de


l’information à l’aide d’une machine électronique (par exemple, Ordinateur)

Introduction à l’informatique
Qu’est ce que l’information ?
L’information est l’élément de connaissance susceptible d'être codé
pour être conservé et traité.
Codage de l’information:
1. L’ordinateur travaille avec des informations codées en bits.
2. Le bit correspond à un état 0 ou 1.
3. L’association de 8 bits, permet de coder 256 informations (caractère).
Par exemple:
• 01000001 Codification de la lettre A
• 01000011 Codification de la lettre C
Unité de capacité:
- 8 bits  1 octet - 1024 octets 1 Ko (Kilo octets).
- 1024 Ko 1 Mo (Mega octets) - 1024 Mo 1 Go (Géga octets).
- 1024 Go 1 To ((Téra octets) - 1024 To  1 Po (Péta octets).
- 1024 Po 1 Eo ((Exa octets) - 1024 Eo  1 Zo (Zettaoctets).
- 1024 Zo Yo (Yottaoctets).

2
12/04/2022

Introduction à l’informatique
Que signifie le terme « traitement » ?
Un traitement est l'ensemble de toutes les opérations que l'on peut
effectuer sur les informations (saisie, modification, mémorisation,
transmission) afin de les rendre manipulables et utilisables.
En général, un traitement peut être schématiser comme suit :
Données à l’état brut
ENTREE
TRAITEMENT Données corrigées
Par ordinateur Résultats
SORTIE
Exemple d’un traitement: traduire un texte

Texte de base (en Traduction Texte traduit (en


français) Par ordinateur arabe)

Introduction à l’informatique
Qu’est ce qu’un ordinateur?
Un ordinateur est une machine (ensemble de circuits électronique) qui
permet le traitement automatique de l’information :
1. Acquisition, stockage : acquérir et conserver de l’information
2. Traitement : effectuer des calcul et exécuter des actions,
3. Restitution : restituer les informations stockées.
• Permet de lier «information»  «données» (0 ou 1)
• Différents types d’informations : valeurs numériques (entiers non
signés, entiers signés, fractionnel,….), textes, images, sons, vidéo…:
codage avec des 0 ou 1.
Le terme "automatique" signifie que l’ordinateur lui-même va
exécuter certaines opérations définies à l’avance (sans intervention
humaine). Par exemple, Guichet automatique bancaire,…

3
12/04/2022

Introduction à l’informatique
Qu’est ce qu’un ordinateur?
Types d’ordinateurs
Toute machine capable de manipuler des informations binaires peut
être qualifiée d'ordinateur. Le type d'ordinateur le plus présent sur
le marché est le PC (Ordinateur personnel), toutefois il existe
d'autres types d'ordinateurs (n'étant pas des PC):
• PC Portable
• Apple Macintosh
• Stations (Alpha, SUN,…)
• …
Un ordinateur se compose de deux parties essentielles :
1. Matériel (Hardware): ensemble d’éléments physiques utilisés pour le
traitement de l’information.
2. Logiciel (Software): ensemble de programmes (algorithmes) servant
à un traitement déterminée.

Introduction à la programmation
Généralités
1. Pour résoudre un problème donné en informatique, l’utilisateur
doit mettre au point un programme et le faire exécuter par un
ordinateur,
2. Un programme est une succession logique et ordonnée d’instructions,
3. La programmation est l’ensemble des tâches qui permettent
d’élaborer un programme.
Pour écrire un programme il faut:
1. Bien analyser le problème;
2. Savoir le découper logiquement en un ensemble d’opérations
élémentaires ( actions)
3. Ecrire un algorithme qui décrit toutes les actions et leurs
séquencement pour obtenir un résultat correct.
4. Traduire l’algorithme en un langage de programmation
compréhensible par la machine.

4
12/04/2022

Introduction à la programmation
Les différentes étapes du processus de programmation

Question: qu’est ce
qu’un algorithme?

Algorithmique: Outils de base


Exemple d’un algorithme?
Ci-dessous, un exemple d’algorithme rédigé en langage courant:

5
12/04/2022

Algorithmique: Outils de base


Qu’est ce qu’un algorithme?
Le terme algorithme vient du nom du célèbre mathématicien
arabo-musulman Al-Khawarizmi (820 après J.C.)
Un algorithme est une description complète et détaillée des actions
à effectuer et de leur séquencement pour arriver à un résultat
donné:
 Intérêt: séparation analyse/codage (pas de préoccupation
concernant la syntaxe des langages de programmation),
 Qualités: exact (fournit le résultat souhaité), efficace (temps
d’exécution, mémoire occupée), clair (compréhensible),
général (traite le plus grand nombre de cas possibles), …
L’algorithmique désigne la discipline qui étudie les algorithmes et
leurs applications en Informatique, afin d’écrire des algorithmes
exacts et efficaces.

Algorithmique: Outils de base


Qu’est ce qu’un algorithme?
Objectifs de l’algorithmique
L’objectif de l’algorithmique est de permettre une bonne
analyse du problème afin de proposer la meilleure solution,
celle-ci doit être correcte, rapide, précise et moins couteuse
en utilisant un ensemble de techniques de programmation.
L’analyse d’un problème en informatique peut prendre jusqu’à
90% du temps alloué à la résolution du problème.
Cette analyse permet:
• De transformer le texte du problème en un ensemble d’étapes
élémentaires
• De revoir les outils élémentaires utilisés dans la solution pour
essayer d’optimiser, si possible, ce schéma avant de procéder à sa
traduction dans un langage de programmation

6
12/04/2022

Algorithmique: Outils de base


Qu’est ce qu’un bon algorithme?
On peut noter qu’un bon algorithme est un schéma de résolution
possédant les caractéristiques suivantes:
 Correct: s’il répond au problème posé.
 Précis: s’il fournit exactement les résultats attendus.
 Rapide: s’il utilise un temps d’exécution minimal
indépendamment de la vitesse de la machine.
 Efficace: s’il utilise le moins d’espace mémoire possible.
 Clair et lisible: s’il ne présente pas de difficulté de
compréhension pour un autre programmeur désirant le
maintenir ou le développer.
 Résistant: s’il est capable de détecter les cas de mauvaise
utilisations.

Algorithmique: Outils de base


Qu’est ce qu’un bon algorithme?

Exemple de résistance d’un algorithme


Dans la résolution d’une équation de premier degré:

a.x+b=0
Pour laquelle:

x=-b/a
Un algorithme de résolution de cette équation doit réagir si on lui
introduit une valeur a=0 ( mauvaise utilisation), en refusant de
calculer la solution et en affichant par conséquent un message
d’erreur, sinon la machine va se bloquer car elle ne sait pas faire
des divisions par zéro.

7
12/04/2022

Algorithmique: Outils de base


Définition d’un algorithme?
Algorithme: Etape 1 … Etape n Opération 1
Opération 1
Opération 2 Opération 2
…. ….
Opération L Opération N

Etape 2 Opération 1
Opération 2
….
Opération M

Un algorithme utilise un certain nombre d’objets pour fonctionner.


Cette ensemble s’appelle: Environnement de l’algorithme.
Objets Constants (OC)

Objets d’Entrées(OE) ALGORITHME Objets de Sortie(OS)

Objets Intermédiaires (OI)

Algorithmique: Outils de base


Définition d’un algorithme?

Cet environnement est constitué de:


1. Objets d’entrée (OE): représentent l’ensemble des données
que l’utilisateur doit introduire à l’algorithme,
2. Objets de sortie (OS): représentent l’ensemble des résultats
produits par l’algorithme.
3. Objets constants (OC): représentent l’ensemble des objets dont
la valeur ne change pas au cours de l’exécution de l’algorithme
4. Objets intermédiaires (OI): représentent l’ensemble des objets
de traitements internes, qui ne sont ni entrés ni sortis, mais ils
peuvent être soit:
 des compteurs,
 des objets calculés à partir des objets d’entrée et des objets
constants et serviront pour produire les objets de sortie.

8
12/04/2022

Algorithmique: Outils de base


Structure simplifiée d’un algorithme
Rappelons qu’:
 Un algorithme est l’ensemble des étapes formé par l’environnement
de l’algorithme et des actions,
 L’environnement d’un algorithme est l’ensemble formé par tous les
objets utilisés par celui-ci.
On distinguera trois parties dans un algorithme:
 Le titre, tout algorithme porte un titre. Choisissez un titre qui permet
de comprendre ce que fait l'algorithme.
 Une partie déclaration, de tous les objets utilisés par l’algorithme
(CONST, VAR)
 Une partie exécutable, contenant toutes les actions permettant
d’agir sur ces objets délimitée par les mots DEBUT et FIN

Algorithmique: Outils de base

Présentation d’un algorithme


Historiquement, deux façons pour représenter un algorithme:
 L’Organigramme: représentation graphique avec des symboles
(carrés, losanges, etc.)
 offre une vue d’ensemble de l’algorithme
 représentation quasiment abandonnée aujourd’hui
 Le pseudo-code: représentation textuelle avec une série de
conventions ressemblant à un langage de programmation
(sans les problèmes de syntaxe)
 plus pratique pour écrire un algorithme
 représentation largement utilisée

9
12/04/2022

Algorithmique: Outils de base


Présentation d’un algorithme
Un algorithme pourra se présenter par un langage algorithmique
(pseudo code) de la manière suivante:
Algorithme nom_algorithme;
(Déclaration)
Const
NOM_DE_CONST=valeur_de_const;
Var
nom_var: nom_type_var;
Début
(Corps de l’algorithme)
(Actions)
Fin

Algorithmique: Outils de base


Exemple des variables et constantes:
CONST ANNEE_COURS=2021;
TAILLE_MIN=1.75;
REPONSE=‘’OUI’’;
VAR Nom, Prenom : chaine de caractère;
Age : entier;
Etat_civil : booléen;
Remarque: si plusieurs objets variables sont de même type, nous
pouvons les regrouper tous ensembles séparés par des virgules.
Exemple d’algorithmes:
• algorithme qui calcul et affiche la somme, le produit et la
moyenne de trois nombres entiers a,b et c.
• algorithme qui calcul le périmètre et la surface d’un cercle de
rayon R.

10
12/04/2022

Algorithmique: Outils de base


Les organigrammes
Un organigramme est une représentation schématique ou
graphique d’un algorithme mettant en valeur sa structure.

Un organigramme permet de mieux présenter les différents


modules de traitement et d’exploiter la succession des
opérations d’un travail

Liste des symboles les plus utilisé dans un organigramme

Séquence Test et Opération: Instruction Sortie disque Début ou fin


décision calcul d’entrée ou de magnétique
sortie

Algorithmique: Outils de base


Les organigrammes : Exemple
Traduction schématique de l’algorithme de calcul du périmètre d’un
cercle de rayon R:
Début

Lecture du
rayon R

P=2*3.14*R

Affichage du
résultat P

Fin

11
12/04/2022

Les outils de base de l’algorithmique

Notion d’objet
Un algorithme est constitué d’un:
 Ensemble fini d’objets appelé environnement,
 Ensemble fini d’actions permettant de traiter ces objets.

Un objet peut se présenter sous deux formes différentes:


 Objet constant : s’il ne peut pas être modifié par les
instructions de l’algorithme tout au long de son exécution.
 Objet variable : dans le cas contraire.

Notion de variable :
Une variable est un emplacement dans la mémoire ou est stockée
une valeur. Pour définir une variable en vue de sa manipulation
par une machine, il faut spécifier les caractéristiques suivantes:
 Son identificateur, Commencer ICI?
 Sa valeur,
 Son type.

Identificateur :
Une variable porte un nom (identificateur), choisit par le
concepteur de l'algorithme, qui doit commencer par une lettre et
ne doit comporter ni d’espace ni de caractères spéciaux.
 La suite des caractères peut être composés:
des lettres non accentuées( a,b,...z, A,B,…Z),
des chiffres ( 0,1,2,….9),
du caractère soulignement « _ ».

12
12/04/2022

Les outils de base de l’algorithmique


Exemple 1
temps, calcul_vectoriel, mois1, a54b2:
sont des identificateurs corrects.
1temps, calcul vectoriel, a54/b2:
sont des identificateurs non corrects.
Remarque: de préférence le nom (identificateur) est choisi en
rapport avec le rôle de l’objet dans le programme.

Exemple 2
Si dans un algorithme de gestion d’une entreprise, on veut
nommer un objet représentant le nombre d’employés, on peut
utiliser:
A: qui est une mauvaise appellation,
NE: qui est une appellation moyenne,
Nbre_employes: qui est une bonne appellation.

Les outils de base de l’algorithmique


Type d’objet
A chaque variable utilisée dans un programme, il faut lui associer un
type qui permet de définir :
• l’ensemble des valeurs que peut prendre la variable,
• l’ensemble des opérations qu’on peut appliquer sur la variable.
La syntaxe de l’action de déclaration d’une variable est la suivante :
Var Variable 1, Variable 2, … : Type

Les principaux types utilisés en algorithmique sont le type :


 entier
 réel
 caractère
 chaîne de caractères
 logique ou booléen

13
12/04/2022

Les outils de base de l’algorithmique


Le type Entier
Une variable est dite entière si elle prend ses valeurs dans l’ensemble Z
(entiers relatifs) et qu’elle peut supporter les opérations suivantes :

Exemples : Autres opérateurs possibles:


17 div 5 = 3 ^ : Exposant
17 mod 5 = 2 <, =, >, <=, >=, <> : Comparaisons
Remarque: L’ensemble des valeurs que peut prendre un entier varie
selon le langage de programmation utilisé.

Les outils de base de l’algorithmique


Le type réel ou décimal
Il existe plusieurs types de réels représentant chacun un ensemble
particulier de valeurs prises dans IR (ensemble des nombres réels).
Ici encore, cette distinction se justifie par le mode de stockage des
informations dans le langage de programmation.
Il existe deux formes de représentation des réels :
 la forme usuelle avec le point comme symbole décimal.
Exemples :
-3.2467 2 12.7 +36.49
 la notation scientifique selon le format aEb, où :
a est la mantisse, qui s’écrit sous une forme usuelle
b est l’exposant représentant un entier relatif.
Exemples :
325 = 3.25E2 = 0.325E+3 = 3250E-1 = ...

14
12/04/2022

Les outils de base de l’algorithmique


Les opérations définies sur les réels sont :

Autres opérateurs possibles:


^ : Exposant
<, =, >, <=, >=, <> : Comparaisons

Les outils de base de l’algorithmique


Le type caractère
• Un caractère peut appartenir au domaine des chiffres de ”0” à
”9”, des lettres (minuscules et majuscules) et des caractères
spéciaux (”*”, ”/”, ”{”, ”$”, ”#”, ”%” …).
• Un caractère sera toujours noté entre des guillemets. Le caractère
espace (blanc) sera noté ” ”.
Les opérateurs définis sur les données de type caractère sont :

Remarque: La comparaison
entre les caractères se fait
selon leur codes ASCII.

Exemples:
” ” < ”0” < ”1” < ”A” < ”B” < ”a” < ”b” < ”{”
34 48 49 65 66 97 98

15
12/04/2022

Les outils de base de l’algorithmique


Code ASCII

Les outils de base de l’algorithmique


Le type logique ou booléen
Une variable logique (ou booléen) peut prendre l’une des deux
valeurs : ”Vrai” ou ”Faux”.
Elle intervient dans l’évaluation d’une condition.
Les principales opérations définies sur les variables de type logique
sont : Négation (NON), Intersection (ET) et Union (OU).
L’application de ces opérateurs se fait conformément à la table de
vérité suivante :

16
12/04/2022

Les outils de base de l’algorithmique


Remarque: les valeurs booléens “Vrai” ou “Faux” peuvent être
aussi représenter par les valeurs : 1 ou 0
Les tables de vérité des opérateurs logiques peuvent alors s’écrire:
A B L=A ET B
0 0 0 A B L=A OU B
0 1 0 0 0 0 A L=NON A
1 0 0 0 1 1 0 1
1 1 1 1 0 1 1 0
1 1 1
L’opérateur ET peut être
matérialisé physiquement L’opérateur OU peut être L’opérateur NON peut être
par deux interrupteurs en matérialisé physiquement matérialisé physiquement par
série pour allumer une par deux interrupteurs en un interrupteur normalement
lampe L parallèle (//) pour allumer fermé au départ pour allumer
une lampe L une lampe L

Les outils de base de l’algorithmique


Type Chaîne de caractère : pour manipuler une suite de caractères,
permettant ainsi de représenter des mots ou des phrases.

• Exemple : "bonjour, Monsieur".

• Remarque: Une chaîne de caractères est toujours notée entre


guillemets " ", pour éviter toute confusion entre des nombres et
des suites de chiffres.

• Par exemple, 423 peut représenter :


 le nombre entier 423 (quatre cent vingt-trois),
 ou la suite de caractères 4, 2, et 3 notée : "423"

17
12/04/2022

Les expressions
Les expressions expriment des expressions arithmétiques (calcul)
ou des expressions logiques (relation). Ce sont des combinaisons
entre des variables et des constantes reliées par des opérateurs.
1. Les expressions arithmétiques:
Exemple : x* 53.4 / (2 + pi)
• L’ordre selon lequel se déroule chaque opération est important.
• Afin d’éviter les ambiguïtés dans l’écriture, on se sert des parenthèses
et la priorité entre les opérateurs arithmétiques :

Ordre de priorité
des opérateurs
arithmétiques

Remarque: En cas de conflit entre deux opérateurs de même priorité, on


commence par celui situé à gauche.

Les expressions
2. Les expressions logiques:
• Ce sont des combinaisons entre des variables et des constantes
reliées par des opérateurs relationnels ou de comparaisons (=, <,
<=, >, >=, #) et/ou des combinaisons entre des variables et des
constantes logiques reliées par des opérateurs logiques (NON ,
ET, OU, …).
• Ici encore, on utilise les parenthèses et l’ordre de priorité entre
les différents opérateurs pour résoudre les problèmes de conflits.

opérateurs logiques
opérateurs relationnels

18
12/04/2022

Les expressions
3. Application1
• L’utilisation la plus fréquente des opérateurs de comparaison est la
comparaison d’expressions logiques;
• La plus simple est la comparaison directe de deux variables
numériques. Exemple:
x y x=y x≠y x<y x>=y x>y x<=y
1 1 Vrai Faux Faux Vrai Faux Vrai
1 2 Faux Vrai Vrai Faux Faux Vrai
2 1 Faux Vrai Faux Vrai Vrai Faux
• Mais, on peut bien sur comparer des expressions numériques
quelconques. Par exemple, pour x=1 et y=2 on aurait:

Expression logique (x+1)=y (x+1)*(y+1)=6 x+1<=2 x-1<-y


Valeur Vrai Vrai Vrai Faux

Les expressions
4. Application2
1. Quel est l’ordre de priorité des différents opérateurs de l’expression
suivante :
((3 * a) – x ^ 2) – (((c – d) / (a / b)) / d)
2. Ecrire la formule suivante sous forme d’une expression arithmétique :

Réponses:

2-

19
12/04/2022

Instructions élémentaires en algorithmique


1. Introduction
Les instructions élémentaires sont les instructions qui figurent le
plus souvent dans tous les algorithmes. Elles sont au nombre de
trois:

1. L’affectation,

2. Les instructions d’entrée de données,

3. Les instructions de sortie de données.

Instructions élémentaires en algorithmique


2. l’affectation
• L’opération affectation permet d’assigner une valeur à un objet.
• Elle est représentée en algorithmique par une flèche orientée de
droite vers la gauche: 
Syntaxe : Identificateur_objet  valeur
L’opération d’affectation présente certaines possibilités et impose
certaines conditions.
2.1 Possibilités
Le membre droite d’une affectation ( valeur) peut être soit:
 Une variable de même type que Identificateur_objet : V  A
 Une constante de même type que Identificateur_objet : C 4
 Une expression dont l’évaluation produit un résultat final de même
type que Identificateur_objet : V  3*A+2*B-4

20
12/04/2022

Instructions élémentaires en algorithmique


2.2 Conditions
Une affectation est exécutable si et seulement si:
 Le membre gauche de l’affectation(identificateur_objet) est une
variable déclarée.
Par conséquent les écritures suivantes n’ont pas de sens:
8 A ou A+B  C
 La partie droite de l’affectation représente une valeur bien
définie.
Par conséquent la 2ème affectation dans l’exemple suivant n’est
pas exécutable:
A  0;
V  1/A;

Instructions élémentaires en algorithmique


 Les types de deux parties de l’affectation sont les mêmes.
Par conséquent la 2ème affectation dans l’exemple suivant n’est pas
exécutable:
Var A: entier;
C: caractère;
Début
A  6;
C  A;
Fin
Exemples d’utilisation de l’affectation A B
En mémoire si A=6 et B=4, 6 4
alors après affectation A  B;
on aura
A B
A=4 et B=4 4 4

21
12/04/2022

Instructions élémentaires en algorithmique


Exemples d’utilisation de l’affectation
 A  3;
A
3
donc A=3. B
B  A; 3
on aura donc B=3. C
C  (A+B)*2; 12
on aura donc C=12.
 i  4;
donc i=4. I
i  i+1; 45
on aura donc i=5;

Remarque: l’affectation détruit complètement et définitivement


le contenu précédent de la variable affectée si elle en avait un.

Instructions élémentaires en algorithmique


Instructions d’entrée/ sortie
Pour bien fonctionner, un algorithme doit en général acquérir des
données (entrées) sur un périphérique (clavier) et fournir des
résultats (sorties) sur un autre périphérique(écran).

Pour réaliser ces tâches fondamentales en programmation, on a


donc besoin de deux opérations distinctes:
1. Lire(v): permet d’affecter à la variable (v) , la valeur lue sur le
périphérique d’entrée (clavier),
2. Ecrire(v1): permet de transformer la valeur ( v1) vers le
périphérique de sortie (écran)

22
12/04/2022

Instructions élémentaires en algorithmique


Instructions d’entrée/ sortie
Remarques
 Pour la lecture, l’identificateur (v) doit être une variable déclarée.
Par conséquent les écritures suivantes n’ont pas de sens:
Lire(8); !!
Lire(A+B); !!
 Pour l’écriture, la valeur de sortie (v1) peut être soit:
Une variable déclarée: Ecrire(A);
Une constante: Ecrire(8);
Une expression : Ecrire( 3*B+4*D-2);
 Un algorithme doit être interactif. Pour faciliter l’utilisation de
l’algorithme en affiche des messages explicatifs qui doivent être
écrits entre apostrophes (” ”).
Ecrire(”Entrez deux valeurs entiers x et y ”);

Instructions élémentaires en algorithmique


Instructions d’entrée/ sortie
Exemple 1
Qu’obtient t-on à l’écran après l’exécution des instructions suivantes :

x  5;
Ville  ”Meknes”;
Ecrire(x); 5
Ecrire(x*x); 25
Ecrire(”Ville”); Ville
Ecrire(”Ville = ”, Ville); Ville = Meknes

23
12/04/2022

Instructions élémentaires en algorithmique


Exemples 2
1. Quelles sont les valeurs successives prises par les variables X et Y suite
aux instructions suivantes:
X 1;
Y  -4;
X  X+ 3; X 1 1 4 -9 -9 -9
X Y-5; Y ---- -4 -4 -4 -7 -13
Y X+2;
Y Y-6;
2. Soit deux variables quelconque (nombre ou caractère) X et Y ayant
respectivement comme valeurs a et b. Quelles sont les affectations qui
donneront à X la valeur b et à Y la valeur a?
Analyse: la première idée peut être d’écrire : XY;
Mais ça ne marche pas, YX;
les deux variables X et Y se retrouvent avec la même valeur b!
 Il faut mettre la valeur de X de coté dans une autre variable
intermédiaire pour ne pas la perdre.

Instructions élémentaires en algorithmique


Algorithme
Algorithme permutation;
Var
X, Y, Z: entier;
Début
Ecrire(”Entrez deux valeurs entières X et Y ”);
Lire(X, Y);
Z X;
XY;
YZ;
Ecrire(”la valeur de X et Y après permutation est:”, X, Y);
Fin X 1; X=1 Y= Z=
Y  -4; X=1 Y=-4 Z=
Vérification! X=1 Y=-4 Z=1
Z  X;
X Y; X=-4 Y=-4 Z=1
Y Z; X=-4 Y=1 Z=1

24
12/04/2022

Instructions élémentaires en algorithmique


Exemple 3 : Donner toutes les raisons pour lesquelles l’algorithme
suivant est incorrect :

Algoritme Incorrect Cet algorithme est incorrect pour plusieurs


raisons :
x, y : Entier;
• ligne 1 : Le mot Algorithme s’écrit avec un
z : Réel; « h » au milieu
• ligne 2 : La déclaration des variables
Début commence par le mot « Var »
z  x + 2; • ligne 5 : La valeur de x est indéterminée
• Ligne 6 : incompatibilité de type (un
y  z; résultat réel affecté à une variable de type
x*2  3 + z; entier)
• Ligne 7 : Le membre gauche d’une
y 5y + 3; affectation doit être une variable
Fin • Ligne 8 : Il faut écrire 5*y et non 5y.

Instructions élémentaires en algorithmique


Exemple 4 : Ecrire un algorithme qui permet de calculer la somme
de deux nombres réels A et B.

Solution
Algorithme somme;
Var
a, b, S: réels;
Début
Ecrire(”Entrez deux nombres”);
Lire(a,b);
S  a+ b;

Ecrire(”la somme de nombres a et b est:” S); ,


Fin

25
12/04/2022

Instructions élémentaires en algorithmique


Remarque : la dernière instruction de l’algorithme précédent peut
être modifier comme suite:
Ecrire(”la somme de deux nombres”, a, ” et ,b, ” est : S); ”,
Exemple: si a=3 et b=8, l’instruction ci-dessus s’exécutera ainsi:

La somme de deux nombres 3 et 8 est :11

Exemple 5: Ecrire un algorithme qui demande un nombre entier


à l'utilisateur, puis calcule et affiche le double de ce nombre.

Instructions élémentaires en algorithmique


Algorithme doubleDevaleure;
Var
val, dval: entiers;
Début Mauvais
Exécution
12 24 val 12; (n’est pas
général)
dvalval*2
Ecrire (val, dval);
Fin
Algorithme doubleDevaleure;
Var
val, dval: entiers;
Début
Exécution: Ecrire(”donner un entier: ”);
Donner un entier: 12 Lire(val);
Le double est 24 dvalval*2 Mieux
Le double de 12 est 24 Ecrire (”le double est ” , dval); (Clair et
Ecrire(”le double de :”,val, ”est ”, dval); général)
Fin

26

Vous aimerez peut-être aussi