Exercice 2 Tableaux

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

Exercice 1 :

Ecrire un algorithme permettant dentrer


cinq valeurs relles au clavier,les stocker
dans un tableau, calculer leur somme et
les afficher avec leur somme lecran.

Correction exercice 1 :

Algorithme tableau_somme;
Var
V : tableau [1..5] de rels ;
S : rel ;
i :entier;
Debut
(*lecture des lements du tableau*)
Pour i <-- 1 5 faire
Ecrire(entrer lelement N ,i);
Lire(V[i]) ;
Finpour i
(*calcul de la somme des lements du
tableau *)
S <-- 0 ;
Pour i <-- 1 5 faire
S <-- S + V[i] ;
Finpour i
(*afficher des lments du tableau *)
Pour i <-- 1 5 faire
Ecrire(lelement N ,i,est : ,V[i]);
Finpour i
Ecrire(la somme des lments du
tableau est :,S) ;
fin
Exercice 2 :
Ecrire un algorithme permettant de saisir et dafficher N lments dun
tableau.
Correction exercice 2 :
Algorithme saisie_affichage;
Var
T : tableau [1..100] de rels ;
N,i : rel ;
Debut
Ecrire(entrer le nombre dlments du tableau :) ;
Lire(N) ;
(*lecture des lements du tableau*)
Pour i <-- 1 N faire
Ecrire(entrer lelement N ,i);
Lire(T[i]) ;
Finpour i
(*afficher des lments du tableau *)
Pour i <-- 1 N faire
Ecrire(lelement T[,i,] est : ,T[i]);
Finpour i
Fin
Exercice 3 :
Ecrire un algorithme permettant de calculer la somme,produit et
moyenne des
lments dun tableau.
Correction exercice 3 :
Algorithme somme_produit_moyenne;
Var
T : tableau [1..100] de rels ;
N,i : entiers ;
S,P,M : rels ;
Debut
Si N=0 alors
Ecrire(le tableau est vide ) ;
Sinon
S <-- 0 ;
P <-- 1 ;
Pour i <-- 1 N faire
S <-- S+T[i] ;
P <-- P * T[i] ;
Finpour i
M <-- S/N ;
Ecrire(la somme des lments du tableau est : ,S);
Ecrire(le produit des lments du tableau est : ,P);
Ecrire(la moyenne des lments du tableau est : ,M);
Finsi
Fin
Exercice 4 :
Ecrire un algorithme permettant de consulter un lment dun tableau.
Correction exercice 4 :
Algorithme consultation;
Var
T : tableau [1..100] de rels ;
N,P : entiers ;
Debut
Si N=0 alors
Ecrire(le tableau est vide ) ;
Sinon
Ecrire(entrer lindice de llment consulter :) ;
Lire(P) ;
Si (P<1) ou (P>N) alors
Ecrire(Position hors limites du tableau )
Sinon
Ecrire(llment consulter est :,T[P]) ;
Finsi
Finsi
Fin
Exercice 5 :
Ecrire un algorithme permettant de chercher toutes les occurrences dun
lment
dans un tableau.
Correction exercice 5 :
Algorithme recherche_toutes_occurences ;
Var
T : tableau [1..100] de rels ;
N,i : entiers ;
X : rel ;
Existe : boolen ;
Debut
Si N=0 alors
Ecrire(le tableau est vide ) ;
Sinon
Ecrire(entrer la valeur de llment chercher :) ;
Lire(X) ;
Existe <-- Faux ;
Pour i <-- 1 N Faire
Si T[i] = X alors
Existe <-- Vrai ;
Ecrire(llment chercher apparait la position : ,i) ;
Finsi
Finpour i
Si Existe = Faux alors
Ecrire(llment napparait pas dans ce tableau ) ;
Finsi
Finsi
Fin

Exercice 6 :
Ecrire un algorithme permettant de chercher la premire occurrence
dun lment
dans un tableau.
Correction exercice 6 :
Algorithme recherche_premire_occurence ;
Var
T : tableau [1..100] de rels ;
P, N,i : entiers ;
X : rel ;
Existe : boolen ;
Debut
Si N=0 alors
Ecrire(le tableau est vide ) ;
Sinon
Ecrire(entrer la valeur de llment chercher :) ;
Lire(X) ;
Existe <-- Faux ;
i <-- 1 ;
tantque (i<=N) et (Existe=Faux) Faire
Si T[i] = X alors
Existe <-- Vrai ;
P<-- i ;
Sinon
i i+1 ;
Finsi
Fintantque
Si Existe = vrai alors
Ecrire(la premire occurrence de llment dans ce tableau est :,P) ;
Sinon
Ecrire(llment napparait pas dans ce tableau ) ;
Finsi
Finsi
Fin
Exercice 7 :
Ecrire un algorithme permettant de
chercher la dernire occurrence dun
lment
dans un tableau.
Correction exercice 7 :
Algorithme recherche_derniere_occurence ;
Var
T : tableau [1..100] de rels ;
P, N,i : entiers ;
X : rel ;
Existe : boolen ;
Debut
Si N=0 alors
Ecrire(le tableau est vide ) ;
Sinon
Ecrire(entrer la valeur de llment
chercher :) ;
Lire(X) ;
Existe <-- Faux ;
i <-- N ;
tantque (i>=1) et (Existe=Faux) Faire
Si T[i] = X alors
Existe <-- Vrai ;
P<-- i ;
Sinon
i <-- i-1 ;
Finsi
Fintantque
Si Existe = vrai alors
Ecrire(la dernire occurrence de llment
dans ce tableau est :,P)
Sinon
Ecrire(llment napparait pas dans ce
tableau ) ;
Finsi
Finsi
Fin

Exercice 8 :
Ecrire un algorithme permettant de
calculer le nombre de fois pour
lesquelles un
lment apparait dans un tableau.
Correction exercice 8 :
Algorithme frequence;
Var
T : tableau [1..100] de rels ;
N,i,F : entiers ;
X : rel ;
Debut
Si N=0 alors
Ecrire(le tableau est vide ) ;
Sinon
Ecrire(entrer la valeur de llment
chercher :) ;
Lire(X) ;
F <-- 0 ;
Pour i <-- 1 N Faire
Si T[i] = X alors
F <-- F+1 ;
Finsi
Finpour i
Ecrire(llment apparait : , F,fois dans
ce tableau ) ;
Finsi
Fin

Exercice 9 :
Ecrire un algorithme permettant
dajouter un lment a la fin dun
tableau.
Correction exercice 9 :
Algorithme Ajout;
Var
T : tableau [1..100] de rels ;
N : entiers ;
X : rel ;
Rep : caractre ;
Debut
Ecrire(entrer la valeur de llment
ajouter :) ;
Lire(X) ;
Ecrire(Confirmer lajout (O/N) :) ;
Lire(Rep) ;
Si Rep =O alors (*la valeur o pour oui
! et N pour Non *)
N<-- N+1 ;(* il y aura un lment en plus
*)
T[N] <-- X ;
Finsi
Fin

Exercice 10 :
Ecrire un algorithme permettant de
modifier un lment dans un tableau.
Correction exercice 10 :
Algorithme Modification;
Var
T : tableau [1..100] de rels ;
N ,P: entiers ;
X : rel ;
Rep : caractre ;
Debut
Si N=0 alors
Ecrire(le tableau est vide ) ;
Sinon
Ecrire(entrer lindice de llment
modifier :) ;
Lire(P) ;
Si (P<1) ou (P>N) alors
Ecrire(Position hors limites du tableau )
Sinon
Ecrire(Lancienne valeur dans cette
position est :,T[p]) ;
Ecrire(Entrer la nouvelle valeur :) ;
Lire(X) ;
Ecrire(Confirmer la modification (O/N) )
;
Lire(Rep) ;
Si Rep=O Alors
T[P]<-- X ;
Finsi
Finsi
Finsi
Fin

Exercice 11 :
Ecrire un algorithme permettant dinsrer un lment dans un tableau
(au dbut , au
milieu ou la fin).
Correction exercice 11 :
Algorithme insertion;
Var
T : tableau [1..100] de rels ;
N ,P,i: entiers ;
X : rel ;
Rep : caractre ;
Debut
Si N=0 alors
Ecrire(le tableau est vide ) ;
Sinon
Ecrire(entrer la valeur de llment insrer :) ;
Lire(X) ;
Ecrire( Entrer la position dinsertion :) ;
Lire(P) ;
Si (P<1) ou (P>N) alors
Ecrire(Position hors limites du tableau )
Sinon
Ecrire(Confirmer linsertion (O/N) ) ;
Lire(Rep) ;
Si Rep=O Alors
N <-- N+1 ;
Pour i <-- N P+1 Faire
T[i] <-- T[i-1] ;
Finpour i
T[P]<-- X ;
Finsi
Finsi
Finsi
Fin

Exercice 12 :
Ecrire un algorithme permettant de
supprimer un lment dans un tableau.
Correction exercice 12 :
Algorithme suppression;
Var
T : tableau [1..100] de rels ;
N ,P,i: entiers ;
Rep : caractre ;
Debut
Si N=0 alors
Ecrire(le tableau est vide ) ;
Sinon
Ecrire(entrer lindice de llment
supprimer :) ;
Lire(P) ;
Si (P<1) ou (P>N) alors
Ecrire(Position hors limites du tableau )
Sinon
Ecrire(la valeur dans cette position est
:,T[P]) ;
Ecrire(Confirmer la suppression (O/N) ) ;
Lire(Rep) ;
Si Rep=O Alors
N <-- N+1 ;
Pour i <-- P N-1 Faire
T[i] <-- T[i+1] ;
Finpour i
N <-- N-1; (*il y aura un lment en
moins*)
Finsi
Finsi
Finsi
Fin

Exercice 13 :
Ecrire un algorithme permettant de trier par ordre croissant les lments
dun
tableau.
Correction exercice 13 :
Algorithme tri_Croissant;
Var
T : tableau [1..100] de rels ;
N ,i,j: entiers ;
Aux: rel ;
Debut
Si N=0 alors
Ecrire(le tableau est vide ) ;
Sinon
Pour i <-- 1 N-1 Faire
Pour j <-- i+1 N Faire
Si T[i] > T[j] alors
Aux <-- T[i] ;
T[i] <-- T[j] ;
T[j] <-- Aux ;
Finsi
Finpour j
Finpour i
Finsi
Fin
Exercice 14 :
Ecrire un algorithme permettant de trier par ordre dcroissant les
lments dun
tableau.
Correction exercice 14 :
Algorithme tri_Dcroissant;
Var
T : tableau [1..100] de rels ;
N ,i,j: entiers ;
Aux: rel ;
Debut
Si N=0 alors
Ecrire(le tableau est vide ) ;
Sinon
Pour i <-- 1 N-1 Faire
Pour j <-- i+1 N Faire
Si T[i] < T[j] alors
Aux <-- T[i] ;
T[i] <-- T[j] ;
T[j] <-- Aux ;
Finsi
Finpour j
Finpour i
Finsi
Fin
Exercice 15 :
Ecrire un algorithme permettant de fusionner les lments de deux
tableaux T1 et T2
dans un autre tableau T.
N.B :
N : nombre des lments du tableau T1
M : nombre des lments du tableau T2
Correction exercice 15 :
Algorithme fusion_deux_tableaux;
Var
T1,T2 : tableau [1..100] de rels ;
T : tableau [1..200] de rels ;
N ,M,i: entiers ;
Debut
Si (N=0) et (M=0) alors
Ecrire(le tableau est vide ) ;
Sinon
Pour i <-- 1 N Faire
T[i] <-- T1[i] ;
Finpour i
Pour i <-- 1 M Faire
T[N+i] <-- T2[i] ;
Finpour i
Finsi
Fin
Exercice 16 :
Ecrire un algorithme permettant de saisir
les donnes dun tableau deux
dimensions (10,4), de faire leur somme,
produit et moyenne et de les afficher avec
les
rsultats de calcul lcran.
Correction exercice 16 :
Algorithme tableau_deux_dimension;
Var
T : tableau [1..10,1..4] de rels ;
I,j: entiers ;
S,P,M : rels ;
Debut
(*saisie des lments du tableau *)
Pour i <-- 1 10 Faire
Pour j<-- 1 4 Faire
Ecrire(entrer lelement T[,i,,,j,] :;
Lire(T[i,j]) ;
Finpour j;
Finpour i
(*calcul de la somme ,produit et moyenne
*)
S <-- 0 ;
P <-- 1 ;
Pour i <-- 1 10 Faire
Pour j<-- 1 4 Faire
S <-- S+T[i,j] ;
P <-- P + T[i,j] ;
Finpour j;
Finpour i
M <-- S/40 ; (*40 : nombre dlment du
tableau = 10x4 *)
(* Affichage des lments du tableau et des
rsultats *)
Pour i <-- 1 10 Faire
Pour j<-- 1 4 Faire
Ecrire(llment T[,i,,,j,] = , T[i,j]);
Finpour j;
Finpour i
Ecrire(la somme des lments du tableau
est :,S) ;
Ecrire(le produit des lments du tableau
est :,P) ;
Ecrire(la moyenne des lments du
tableau est :,M) ;
Fin

Exercice 17 :
Ecrire un algorithme qui calcule la somme des lments de la diagonale
dune matrice
carre M(n,n) donne.
Correction exercice 17:
Algorithme diagonale_de_matrice;
Const
N=8 ;
Var
M : tableau [1..8,1..8] dentiers;
i,j: entiers ;
Sdiag: entiers;
Debut
(*saisie des lments de la matrice*)
Pour i <-- 1 n Faire
Pour j<-- 1 n Faire
Ecrire(entrer lelement M[,i,,,j,] :;
Lire(M[i,j]) ;
Finpour j;
Finpour i
(*calcul de la somme des lments de la diagonale *)
Sdiag <-- 0 ;
Pour i <-- 1 n Faire
Sdiag <-- Sdiag +M[i,j] ;
Finpour i
Ecrire(la somme des lments de la diagonale est :,Sdiag) ;
Fin

Exercice 18 :
Ecrire un algorithme permettant deffectuer le produit des matrices
A(n,m) et B(m,p) .
n ,m et p donnes (par exemple n=4,m=5,p=3 ).
N.B :
Pour pouvoir faire le produit de deux matrices, il faut absolument que le
nombre
de colonnes
de la premire soit gal au nombre de lignes de la deuxime.
Correction exercice 18 :
Algorithme produit_matrices;
Const
n=4;
m=5;
p=3;
Var
A : tableau [1..n,1..p] de rels;
B : tableau [1..p,1..m] de rels;
C : tableau [1..n,1..m] de rels;
i,j: entiers ;
Debut
(*lecture des lments des deux matrices*)
Pour i <-- 1 n Faire
Pour j<-- 1 p Faire
Ecrire(entrer lelement A[,i,,,j,] :);
Lire(A[i,j]) ;
Finpour j;
Finpour i
Pour i <-- 1 p Faire
Pour j<-- 1 m Faire
Ecrire(entrer lelement B[,i,,,j,] :);
Lire(B[i,j]) ;
Finpour j;
Finpour i
(*calcul de produit des deux matrices*)
Pour i <-- 1 n Faire
Pour j<-- 1 m Faire
C[i,j] <-- 0 ;
Pour k <-- 1 p faire
C[i,j] <-- C[i,j] + A[i,k] *B[k,j] ;
Finpour k
Finpour j;
Finpour i
(*Affichage de la matrice produit*)
Pour i <-- 1 n Faire
Pour j<-- 1 m Faire
Ecrire(lelement C[,i,,,j,] =,C[i,j]);
Finpour j;
Finpour i
Fin
Exercice 19 :
Ecrire un algorithme permettant de construire dans une matrice carre P
et dafficher
le triangle de PASCAL de degr N.
N.B :
On poura utiliser cette relation pour les lments de triangle de
PASCAL :
Pi,j = Pi-1,j-1 + Pi-1,j
Exemple : triangle de pascal de degr 5 :
N=0 - 1
N=1 - 1 1
N=2 - 1 2 1
N=3 - 1 3 3 1
N=4 - 1 4 6 4 1
N=5 - 1 5 10 10 15 1
Correction exercice 19 :
Algorithme triangle_pascal;
Var
P: tableau [1..100,1..100] de rels;
i,j,n: entiers ;
Debut
Ecrire(entrer lordre du triangle de pascal que vous voulez :) ;
Lire(n) ;
(*remplissage du triangle de Pascal*)
P[1,1] <-- 1 ;
Pour i <-- 2 n+1 Faire
P[i,1] <-- 1 ;
Pour j<-- 2 i-1 Faire
P[i,j] <-- P[i-1,j-1] + P[i-1,j]
Finpour j;
P[i,j] <-- 1 ;
Finpour i
(* affichagedu triangle de Pascal*)
Pour i <-- 1 n+1 Faire
Pour j<-- 1 i Faire
Ecrire(P[i,j] , );
Finpour j;
(*retour a la ligne *)
Finpour i
Fin

Vous aimerez peut-être aussi