You are on page 1of 20

EPREUVE THEORIQUE D’INFORMATIQUE

Correction officielle - Made in


Tunisia

Sections : Math - Tech - Sc.Exp

Ridha Nairi

2008, 2009, 2010 et 2011.

Edition le libre savoir


REPUBLIQUE TUNISIENNE
MINISTERE DE L’EDUCATION ET
Sections : Math. + Tech. + Sc.Exp.
DE LA FORMATION EPREUVE THEORIQUE D’INFORMATIQUE
***
EXAMEN DU BACCALAUREAT
SESSION 2008 (SP)
SOLUTION
DUREE : 1 h COEFFICIET : 0.5

PARTIE I (8 points)
Exercice 1 : (3 points = 4 x 0,75)
Compléter le tableau ci-dessous, par les déclarations Pascal adéquates :
0.25 / mot clé + 0.5 pour la suite de la déclaration
Déclaration en Pascal (Préciser le
Description mot clé adéquat : COST, TYPE, Remarques
VAR, etc.)
Une chaîne ch de 20 Var
caractères au ch : string[20] ;
maximum.
Un type saison L’ordre est
contenant les Type saison = (Automne, Hiver, important
identificateurs Printemps, ete) ;
suivants : Automne,
Hiver, Printemps, ete.
Un tableau V dont les On acceptera
indices sont de type Var toute
combinaison
caractère pouvant V : array[’A’. . ‘T’] of string ; équivalente de
contenir 20 chaînes. 20 éléments

Une constante message


Const
de valeur « Bonne
chance ». Message=‘Bonne chance’ ;

Exercice 2 : (2 points = 8 x 0,25)


Soit la fonction Existe dont l’algorithme est donné ci-dessous :
0) DEF FN Existe ( n: entier ; T : tab ; x : réel) : booléen
1) Trouve  faux
2) i 0
3) Répéter
i  i +1
Si (T[i] = x) alors
Trouve  vrai
FinSi
4) Jusqu’à (Trouve) ou (i =n)
5) Existe  Trouve
6) Fin Existe

2008 | 1/6
On acceptera que le type de la fonction soit chaîne avec la séquence 5)
une structure conditionnelle cohérente.

Compléter l’algorithme de la fonction Existe, dont les paramètres sont


x, n et T, qui permet de vérifier l’existence d’un élément x dans un
tableau T de n réels.

Exercice 3 : (3 points)
Compléter les affectations suivantes par une valeur d’opérande ou d’opérateur
permettant d’obtenir dans chacun des cas, la valeur de Y voulue :
Affectations Valeur de Y
Y := round(99,51) = 100 ; True
Toute valeur
Y := (upcase(‘a’) in [‘A’ .. ‘Z’]) and (1 in [1..10]); True comprise
entre 1 et 10
Y := length(‘PASCAL’) mod 4 = 2 ; True
Y :=
Y := random(4) < 4; True random(4) <>
4;
Y := pred(‘D’) = chr(ord(‘B’) + 1); True
Y := copy(‘informatique’,1,4) <> ‘info’; False

B. : Certaines affectations ont plusieurs solutions correctes.

2008 | 2/6
Solution de la partie 2 : (12 points)
1) Structures données ( 1.5 pt )
On évaluera les structures de données de base et non les compteurs (la chaîne à traiter, le
conteneur des fréquences des lettres, la variable pour les caractères non alphabétiques)
La chaîne à traiter sera nommée ch.
Les résultats du problème peuvent être récupérées dans un tableau LET pour les lettres et dans
une variable NLET pour les autres.
Le tableau LET est de type TLET qui est un tableau de 26 entiers et qui aura comme indices la
plage des lettres alphabétiques majuscules "A" à "Z".

2) Analyse du programme principal et des modules


Points clés de l’analyse Barème
Programme principal 1.5
(modularité + cohérence)
Saisie contrôlée de ch 1
Le comptage 2 + 0.5 (initialisation)
Premier affichage 0.25
Deuxième affichage 1
Troisième affichage 0.25
TDO et TT 0.5

OM = nbre_lettres
S L.D.E. O.U.
3 Résultat = (Ecrire(" Votre texte comporte " , longueur(ch), " caractères dont : "), afficher
2 PROC afficher(LET), écrire(" et " , NLET, " caractères non alphabétiques.") decompte
1 (LET, NLET) = PROC decompte(ch, LET, NLET) LET
ch = REPETER NLE
DONNEE ("Chaîne à traiter :") Ch
JUSQU'A (longueur (ch) dans [1..100])
4 Fin nbre_lettres

Tableau de déclaration des nouveaux types

TYPE
TLET tableau de 26 entiers et dont les indices sont "A", "B", … , "Z"

Tableau de déclaration des objets

OM TYPE ROLE


afficher procédure - permet d'afficher les éléments du tableau avec
les commentaires relatifs
decompte procédure - permet de déterminer la décomposition de la
chaîne
LET TLET - ses éléments comportent respectivement le
nombre d'une lettre de la chaîne ch.
NLET Entier - le nombre de caractères non alphabétiques
ch Chaine[100] - chaîne à traiter

3) Analyse des modules

Analyse du module afficher

2008 | 3/6
DEFPROC afficher(TL : TLET)
S L.D.E. O.U.
Résultat = affiche_lettres c
1 affiche_lettres = [ ] Pour c de "A" à "Z" faire
[ ] Si (TL[c] ≠ 0) alors
Ecrire(TL[c], " fois la lettre ", c)
FinSi
FinPour
2 Fin afficher

Tableau de déclaration des objets locaux

OM TYPE ROLE


c caractère compteur et en même temps indice

Analyse du module decompte

DEFPROC decompte(cht : chaine[100] ; VAR TL : TLET ; VAR NLT : entier)


S L.D.E. O.U.
Résultat = (TL, NLT) l
1 (TL, NLT) = [l←Long(cht), NLT  0, PROC init(TL),] init
Pour i de 1 à l Faire i
[c ← Majus(cht[i])] Si (c dans ["A".."Z"]) alors c
TL[c] ← TL[c] + 1
Sinon
NLT ← NLT + 1
FinSi
FinPour
2 Fin decompte

Tableau de déclaration des objets locaux

NOM TYPE ROLE


l entier longueur de la chaîne
init procédure locale à decompte sert à initialiser à 0 les éléments du tableau TL
i entier compteur
c caractère compteur

Analyse du module init

DEFPROCinit(VAR TL : TLET)
S L.D.E. O.U.
Résultat = TL c
1 TL = [ ] Pour c de "A" à "Z" Faire
TL[c] ← 0
FinPour
2 Fin init

2008 | 4/6
Tableau de déclaration des objets locaux

OM TYPE ROLE


c caractère compteur et en même temps indice

4) Les algorithmes

Algorithme du programme principal (1pt)

0) Debut nbre_lettres
1) REPETER (Saisie contrôlée 0.5 pt)
DONNEE ("Chaîne à traiter :")
JUSQU'A (longueur (ch) dans [1..100])
2) PROCdécompte(ch, LET, NLET)
3) Ecrire(" Votre texte comporte " , longueur(ch), " caractères dont : "), PROC
afficher(LET), écrire(" et " , NLET, " caractères non alphabétiques.")
4) Fin nbre_lettres

Algorithmes des modules (2,5pt -0.25 / faute)

Algorithme du module afficher (1pt)

0) DEFPROCafficher(TL : TLET)
1) Pour c de "A" à "Z" faire
Si (TL[c] ≠0) alors
Ecrire(TL[c], " fois la lettre ", c)
FinSi
FinPour
2) Fin afficher

Algorithme du module decompte et init (1pt)

0) DEFPROCdecompte(cht : chaine[100] ; VAR TL : TLET ; VAR NLT : entier)


1) [l←Long(cht),PROC init(LT)] Pour i de 1 à l Faire
[c ← Majus(cht[i])] Si (c dans ["A".."Z"]) alors
TL[c] ← TL[c]+1
Sinon
NLT ← NLT + 1
FinSi
FinPour
2) Fin decompte

Algorithme du module init

0) DEFPROC init(VAR TL : TLET)


1) Pour c de "A" à "Z" Faire

2008 | 5/6
TL[c] ← 0
FinPour
2) Fin init

2008 | 6/6
Correction Informatique Section Sections Scientifiques
Session Juin 2009

PARTIE I (8 points)
Exercice N°1 : (1,5 points = 0,25 x 6)
Règles à appliquer :
Si la définition d’un module M nécessite la déclaration de X objets notés Oi et de Y sous-modules
notés Mi, alors les X objets Oi seront reconnus par le module M mais également par les Y sous-
modules Mi.
Application de la règle sur l’objet p :
La définition du module Somme nécessite la déclaration de l’objet p et d’une fonction Produit,
donc p est reconnu par le module Somme mais également par le sous-module Produit.

Application de la règle sur les objets q et r :


La définition du module Produit nécessite la déclaration des objets q et r et d’aucun sous-module,
donc q et r sont reconnus par le module Produit et ne seront pas reconnus ailleurs.

Reconnu par la fonction


Objet Somme Produit
p O O
q N O
r N O
NB: On n'acceptera que les réponses O/N et Oui/Non

Exercice N°2 : (3,5 points = 0,5 par croix et 0,25 par justification = 0.5*6 + 0.25*2)
Readln(jour) ; Cette instruction n’est pas valide car, on ne peut pas lire une variable de
type scalaire énuméré.
langue :=Anglais ; Cette instruction est valide. En effet, langue étant une variable de type
langues_etrangeres et Anglais étant une des valeurs de cet ensemble, l’affectation est
possible.
aujourdhui := Dimanche ; Cette instruction est valide. En effet, aujourdhui étant une
variable de type jour_semaine et dimanche étant une des valeurs de cet ensemble,
l’affectation est possible.
Writeln(langue) ; Cette instruction n’est pas valide car, on ne peut pas afficher une
variable de type scalaire énuméré.
res := aujourdhui<jour ; Cette instruction est valide. En effet, il s’agit d’affecter à une
variable de type logique (res) le résultat de la comparaison aujourdhui<jour, qui est un
résultat de type logique.
Exemple : si aujourdhui vaut Dimanche et jour vaut Lundi, alors
aujourdhui<jour est faux, car ord(Dimanche) > ord(jour)
n := ord(langue) ; Cette instruction est valide. En effet, il s’agit d’affecter à une variable de
type entier (n) le numéro d’ordre (ord) du contenu de la variable langue. Ce numéro est
un entier.

2009 | 1/6
Exemple : si langue vaut Anglais, alors ord(langue) = 1 et n vaut 1.

Exercice N°3 (3 points = 1 + 1 + 1)


1. Function Essai (ch: string; nb, p: integer): string; (1 pt=2*0,5)
Var
i : Byte ; r : string ; Il est possible d'accepter le type Integer pour la variable i.
Begin
r := ’’;
For i:=1 to length (ch) do
if i in [p..p+nb-1] then r := r + ch[i];
Essai := r;
End;
2. Le résultat de cette fonction pour les paramètres effectifs suivants :
Ch = ‘Protocole’ p= 3 et nb= 4
Ch ‘Protocole’ ‘Protocole’ ‘Protocole’ ‘Protocole’ ‘Protocole’ ‘Protocole’ ‘Protocole’ ‘Protocole’ ‘Protocole’
Nb 4 4 4 4 4
P 3 3 3 3 3
I 1 2 3 4 5 6 7 8 9
r ‘’ ‘’ ‘o’ ‘ot’ ‘oto’ ‘otoc’ ‘otoc’ ‘otoc’ ‘otoc’

La fonction retourne la valeur : otoc (1 pt)


3. la fonction essai renvoie une sous-chaîne de nb caractères et formée à partir d’une
chaîne notée Ch en commençant à la position p. Il s’agit de la fonction prédéfinie
COPY (Ch, p, nb). (1 pt)

PARTIE II (12 points)


Analyse (8 Pts) Algorithme
• On acceptera toute forme d'analyse descendante. • Pour être évalué,
l'algorithme doit présenter
• On acceptera toute solution correcte.
un contenu en relation avec
le problème demandé

PP (1,5 pts) • PP (1 pt)


• Cohérence=0,5
• Modularité= 1

Saisie (1,5 pts) Saisie (1 pt)


• Taille = 0,25*2

2009 | 2/6
Fusion (1,5 pt)
• Union = 1
• Ordre = 1
• Redondance = 1
Affichage (1 pts=2*0,5)
Divers (1 pts)
• Entête des modules (mode de passage, ordre et types
de paramètres)
• T.D.O et des nouveaux types Affichage (0,5 pt)

Nom = Distinct
S L.D.E. O.U.
4 Résultat = Proc Afficher (K, V3) K, V3
3 (K, V3) = Proc Fusion (N, M, V1, V2, K, V3) Afficher
2 (N, V1) = Proc Saisie (N, V1) Fusion
1 (M, V2) = Proc Saisie (M, V2) N, V1
5 Fin M, V2, saisie

Tableau de déclaration des nouveaux types

Type
Tabd =Tableau de 20 entiers
Tabr = Tableau de 40 entiers

T.D.O.G
Nom Type Rôle
K Entier Longueur du tableau final V3
N Entier Longueur du tableau V1
M Entier Longueur du tableau V2
V1 Tabd Tableau donné
V2 Tabd Tableau donné
V3 Tabr Tableau final
Afficher Procédure Affiche le tableau final
Saisie Procédure Saisie d’un tableau et sa longueur
Fusion Procédure Fusionne V1 et V2 dans V3 sans redondance

DEF PROC Saisie (var Nb : entier ; var T :Tabd) Commentaires


S L.D.E. O.U.
Résultat = Nb, T
1 Nb = [ ]
Répéter • Validation de la

2009 | 3/6
Nb = donnée taille des tableaux
Jusqu’à Nb dans [2..20]
T= [ T[1] = donnée] • Lecture de
2 Pour i de 2 à Nb faire i l’élément n°1
Répéter • Tous les autres
T[i]=donnée éléments doivent être
Jusqu’à T[i] > T[i-1] dans un ordre
Fin pour strictement croissant
Fin
3

T.D.O.L
Nom Type Rôle
i Entier Compteur

DEF PROC Fusion (N, M : Entier ; V1, V2 : Tabd ; Var K :


Entier ; Var V3 : Tabr)
S L.D.E. O.U. Commentaires
Résultat = K, V3
1 (K,V3)=[i1, j 1, K 0] i, j
Répéter
K K+1 • L’élément de V1 est plus
Si V1[i]<V2[j] alors petit que celui de V2, on
V3[K] V1[i] range V1[i] et on avance dans
i  i+1 V1
Sinon • Ecriture d’un seul élément
Si V1[i]=V2[j] alors (sans redondance)
V3[K] V1[i] • L’élément de V2 est plus
i i+1 petit que celui de V1, on
j j+1 range V2[j] et on avance dans
Sinon V2
V3[K] V2[j] • Répétition du traitement
j  j+1 jusqu’à la fin de V1 ou de V2.
FinSi
FinSi • Ecriture des éléments de V1
Jusqu’à (i>N) ou (j>M) (car c’est la fin de v2)
Si j>M Alors
2
Pour c de i à N faire c • Ecriture des éléments de V2
K K+1 (car c’est la fin de V1)
V3[K]  V1[c]
Fin pour
Sinon
Pour c de j à M faire
K K+1
V3[K]  V2[c]
Fin Pour

2009 | 4/6
T.D.O.L
Nom Type Rôle
i Entier compteur
j Entier compteur
c Entier compteur

DEF PROC afficher ( Nb : entier ; T :tabr)


S L.D.E. O.U.
Résultat = [ ]
1 Pour i de 1 à Nb faire i
Ecrire (T[i])
Fin pour
2 Fin
T.D.O.L
Nom Type Rôle
I Entier compteur

Les algorithmes
Programme Principal
0) Début Distinct
1) Proc Saisie (N, V1)
2) Proc Saisie (M, V2)
3) Proc Fusion (N, M, V1, V2, K, V3)
4) Proc Afficher (K, V3)
5) Fin Distinct

Procédure Saisie
0) DEF PROC saisie (Var Nb : Entier ; Var T :Tabd)
1) Répéter
Lire (Nb)
Jusqu’à Nb dans [2..20]
lire(T[1])
2) Pour i de 2 à Nb faire
Répéter
Lire (T[i])
Jusqu’à T[i] >T[i-1]
Fin pour
3) Fin saisie

Procédure Fusion
0) DEF PROC Fusion (N, M : entier ; V1,V2 : tabd ; var K : entier ; var V3 : tabr)
1) i1, j 1, K 0
Répéter
K K+1

2009 | 5/6
Si V1[i]<V2[j] alors
V3[K] V1[i]
i  i+1
Sinon
Si V1[i]=V2[j] alors
V3[K] V1[i]
i  i+1
j  j+1
Sinon
V3[K] V2[j]
j  j+1
FinSI
FinSi
Jusqu’à (i>N) ou (j>M)
2)
Si j>M Alors
Pour c de i à N faire
K K+1
V3[K]  V1[c]
Fin pour
Sinon
Pour c de j à M faire
K K+1
V3[K]  V2[c]
Fin Pour
3) FinSi
Fin Fusion

Procédure Afficher
0) DEF PROC Afficher ( Nb : entier ; T :tabr)
1) Pour i de 1 à Nb faire
Ecrire (T[i])
Fin pour
2) Fin Afficher

2009 | 6/6
EXAMEN DU BACCALAUREAT - SESSION DE JUIN 2010
SECTIONS : Mathématiques + Sciences Expérimentales + Sciences Techniques
Corrigé
Partie I (6 points)
Exercice 1 (3 points : 1 x 3)
On suppose qu'un programme principal contient trois sous programmes (une procédure Proc1, une
fonction Fonct et une procédure Proc2).
Compléter le tableau suivant par un exemple d’appel de chacun des sous programmes au niveau du
programme principal, en se basant sur les entêtes et sur la liste des variables globales disponibles.

Exemple d'appel du sous


Variables
Entête du sous programme programme dans le programme
globales
principal
Proc Proc1(a, b, x) ou
Procédure Proc1 (VAR m,n:entier; z:réel)
Proc Proc1(b, a, x)
a, b : entier
x : réel car  Fn Fonct(a, Mot) ou
Fonction Fonct(n:entier; ch:chaîne):caractère car : caractère car  Fn Fonct(b, Mot) ou
Mot : chaîne Ecrire(Fn Fonct(b, Mot))
Procédure Proc2 (Ch:chaîne ; VAR c:caractère) Proc Proc2(Mot, car)

On pourra accepter toute solution équivalente.

Exercice 2 (3 points)

Soit le programme Pascal suivant :

Program ESSAI ; Questions


Uses wincrt ; 1) Compléter le tableau suivant par la nature de
Var y : integer ; chaque objet utilisé (objet local ou objet global)
(2x0,5)
Function Fonct (a : integer): Char;
Objet Nature
Begin
Fonct := Chr(2*a); y Global
End; m Local

Procedure Proc ;
Var 2) Pour les objets y, m, Proc et Fonct, compléter le
m : Char; tableau ci-dessous en mettant une croix (x) dans la
Begin case correspondante si l'objet est visible par le
m:=Fonct(y); programme principal "ESSAI" ou par les sous
Writeln(m); programmes :
End;
(4 x 0,5 = 0,5 par ligne)
Begin - 0,25 par erreur
Readln(y);
Proc; Programme
Sous programmes
End. principal
Objet ESSAI Proc Fonct
y x x x
m x
Proc x
Fonct x x

2010 | 1/4
Partie II (14 points)
On se propose d'écrire une analyse et un algorithme d'un programme "Tri" qui permet de remplir
un tableau T par n entiers distincts puis de former et d'afficher un autre tableau Res qui va contenir
les n entiers du tableau T classés en ordre croissant selon le principe suivant :
Pour chaque élément du tableau T
1) Déterminer le nombre Nbr d'éléments de T qui lui sont inférieurs ou égaux.
2) Placer cet élément dans la position Nbr du tableau Res.

Exemple : pour les éléments du tableau suivant :

T 3 14 0 9 17 5 8 4
1 2 3 4 5 6 7 8

 L'entier T[1] = 3 a 2 éléments qui lui sont inférieurs ou égaux (3 et 0), il sera placé dans la
position 2 du tableau Res.
Res 3
1 2 3 4 5 6 7 8

 L'entier T[2] = 14 a 7 éléments qui lui sont inférieurs ou égaux (3 , 14 , 0 , 9 , 5 , 8 et 4), il


sera placé dans la position 7 du tableau Res.
Res 3 14
1 2 3 4 5 6 7 8

 ainsi de suite pour les autres éléments …

Le tableau Res aura les éléments placés dans un ordre croissant, comme suit :

Res 0 3 4 5 8 9 14 17
1 2 3 4 5 6 7 8

Questions :
1. Analyser le problème en le décomposant en modules et déduire un algorithme du
programme principal.
2. Analyser chacun des modules proposés.

Analyse du Programme Principal


Résultat = Proc Affiche (N, RES)
RES = PROC Trier (N, T, RES)
(N, T) = PROC Lecture (N, T)

Tableau de déclaration des nouveaux types


Types
TAB = Tableau de 50 entiers

2010 | 2/4
Tableau de déclaration des Objets
Objet Type/Nature Rôle
N Entier Dimension du tableau
T Tab Tableau d’entiers
RES Tab Tableau trié
Affiche procédure Permet d’afficher les éléments du tableau RES
Trier procédure Permet de trier le tableau T dans RES
Lecture Procédure Permet la saisie contrôlée de N et le remplissage
du tableau T avec contrôle.

Algorithme du programme Principal


0) Début TRI
1) PROC Lecture (N, T)
2) PROC Trier (N, T, RES)
3) PROC affiche (N, RES)
3) Fin TRI

Analyse de la procédure Afficher :


DEF PROC Afficher (N : entier ; RES : Tab)
Résultat = Affiche_RES
Affiche_RES = [] Pour i de 1 à N faire
Ecrire ("RES[",I , "]= ",RES[i])
Fin Pour
Tableau de déclaration des Objets
Objet Type/Nature Rôle
i Entier Compteur

Analyse de la procédure Lecture :


DEF PROC Lecture(var N:entier;Var T:tab)
Résultat = (N, T)
T= [T[1] = Donnée]
Pour i de 2 à N Faire
Répéter
T[i]= Donnée ("T[",i, "]= ")
Jusqu’à FN existe (T, i) = Faux
FinPour
N= [] Répéter
N= donnée("N= ")
Jusqu'à (N>1)
Tableau de déclaration des Objets
Objet Type/Nature Rôle
i Entier Compteur
Existe Fonction Permet de vérifier l’existence d’un élément dans un tableau

Analyse de la fonction Existe :


DEF FN existe (V : Tab ; C : entier) : Booléen
Résultat = ExisteE
E = [K  0]
Répéter
K  K+1
E  V[K] = V[C]
Jusqu’à (E) ou (K = C-1)
2010 | 3/4
Tableau de déclaration des Objets
Objet Type/Nature Rôle
E Booléen Indiquer l’existence ou non d’un élément dans un tableau
K Entier Compteur

Analyse de la procédure Trier:


DEF PROC Trier (N:entier ; T:tab; VAR RES:TAB)
Résultat = RES
RES = [] Pour i de 1 à n faire (0,5 point)
[K0] Pour j de 1 à n Faire (0,5 + 0,5 point)
[]Si T[j] <= T[i] Alors k k+1 (1,5 points)
Finsi
FinPour
RES[K] T[i] (0,5 point)
FinPour

Tableau de déclaration des Objets


Objet Type/Nature Rôle
i Entier Compteur
j Entier Compteur
K Entier Compteur
Barème
Modularité Décomposition + Cohérence 1,5 points + 1 point
Algorithme du PP 1 point
Lecture Saisie N + Contrôle sur la valeur de N 0,5 point + 0,5 point
Remplissage du tableau T + Contrôle 1,5 points + 1,5 points
que les éléments de T sont distincts
Trier Voir Détails plus haut 3,5 points
Afficher Affichage du tableau RES 1 point
TDNT 0,5 point
TDO 1,5 points

NB : - 0,25 par erreur


L’erreur n’est pénalisée qu’une seule fois.

2010 | 4/4
Correction Informatique Sections Scientifiques. Session Juin 2011

PARTIE I (6 points)

Exercice 1 (4 points)
1) 8
2) 17
3) La fonction retourne la somme des chiffres qui composent l’entier n.

Exercice 2 (2 points)

Proposition Réponse
Un tableau de réels peut être rempli par des entiers. Vrai
Le compteur d'une structure répétitive doit être de type scalaire. Vrai
Les opérateurs DIV et MOD peuvent être appliqués sur les nombres réels. Faux
Efface (ch,longueur(ch)-1,2) efface les deux derniers caractères de la chaîne ch. Vrai

PARTIE II (14 points)

Analyses : 8 points, Algorithme 4 points, paramètres et objets Locaux et Globaux : 2 points

ANALYSE DU PROGRAMME PRINCIPAL :


NOM= Valable
2. Résultat= PROC Affiche(n)
1. PROC Saisie(n)
3. Fin Valable
T.D.O
Objet Type/Nature Rôle
n Entier Le nombre d’éléments
Affiche Procédure Procédure de d’affichage
saisie Procédure Procédure de saisie

ALGORITHME DU PROGRAMME PRINCIPAL :


0) Début Valable
1) PROC Saisie(n)
2) PROC Affiche(n)
3) Fin Valable

ANALYSE DE LA PROCEDURE SAISIE :


DEF PROC Saisie(var m:entier)
2. Résultat= (m)
1. m= [] Répéter
m = donnée
Jusqu’à (m >= 1000) et (m<=9999)
3.Fin Saisie.

ALGORITHME DE LA PROCEDURE SAISIE :


0) DEF PROC Saisie(var m:entier)
1) Répéter
Lire(m)
Jusqu’à (m >= 1000) et (m<=9999)
2) Fin Saisie
2011 | 1/2
ANALYSE DE LA PROCEDURE AFFICHE :
DEF PROC Affiche (p:entier)
2) Résultat = Affich
1) Affich = [] Si Valable (p) = Vrai Alors Ecrire (p, "est valable")
Sinon Ecrire (p, "n’est pas valable")
FinSi
3) Fin Affiche

ALGORITHME DE LA PROCEDURE AFFICHE

0) DEF PROC Affiche (p:entier)


1) Si Valable(p) = vrai Alors Ecrire (p, "est valable")
Sinon Ecrire (p, "n’est pas valable")
FinSi
2) Fin Affiche

ANALYSE DE LA FONCTION VALABLE :

DEF FN Valable (k:entier): booléen


3) Résultat = Valable
2) Valable = [] Si (c mod m = 0) et (d mod m = 0) et (u mod m = 0) Alors Valable  vrai
Sinon Valable  faux
FinSi

1) m k div 1000
c k mod 1000 div 100
d k mod 100 div 10
u k mod 10
4) Fin Valable.
T.D.O
Objet Type/Nature Rôle
m entier Chiffre des milliers.
c entier Chiffre des centaines.
d entier Chiffre des dizaines.
u entier Chiffre des unités.
ALGORITHME LA FONCTION VALABLE :

0) DEF FN Valable (k:entier): booléen


1) m k div 1000
c k mod 1000 div 100
d k mod 100 div 10
u k mod 10
2) Si (c mod m = 0) et (d mod m = 0) et (u mod m = 0) Alors Valable  vrai
Sinon Valable  faux
FinSi
3) Fin Valable

2011 | 2/2
© Edition le libre savoir

You might also like