0% ont trouvé ce document utile (0 vote)
33 vues59 pages

Cours C++

Transféré par

Armel CAT
Copyright
© © All Rights Reserved
Nous prenons très au sérieux les droits relatifs au contenu. Si vous pensez qu’il s’agit de votre contenu, signalez une atteinte au droit d’auteur ici.
Formats disponibles
Téléchargez aux formats PDF, TXT ou lisez en ligne sur Scribd
0% ont trouvé ce document utile (0 vote)
33 vues59 pages

Cours C++

Transféré par

Armel CAT
Copyright
© © All Rights Reserved
Nous prenons très au sérieux les droits relatifs au contenu. Si vous pensez qu’il s’agit de votre contenu, signalez une atteinte au droit d’auteur ici.
Formats disponibles
Téléchargez aux formats PDF, TXT ou lisez en ligne sur Scribd

LANGAGE C++

Elaboré par Armel HOUEHOMEGAN


Ingénieur Informatique
Tél. : +229 01 66 440 575 | Email : periclepss@[Link]

1
CHAPITRE 1:

PRESENTATION DU LANGAGE C++

1. HISTORIQUE DU C++ :
Le langage C++ est un des langages les plus célèbres au monde. Très utilisé, notamment
dans le secteur des jeux vidéo qui apprécie ses performances et ses possibilités, le C++ est
désormais incontournable pour les développeurs.
Les concepts de la programmation C++ ont été conçus par Bjarne Stroustrup en 1982 aux
ATT Bell Laboratoires. L’idée était d’ajouter au C des possibilités sur l’orienté objet et de
pallier aux inconvénients du C. De ce fait, le C++et en même temps un langage classique
comme le C et un langage orienté objet (P.O.O) comme JAVA.
En effet, Bjarne Stroustrup, son créateur, a cherché à adjoindre à un langage structuré
existant (le C), un certain nombre de spécificités lui permettant d’appliquer les concepts de
P.O.O. Dans une certaine mesure, il a permis à des programmeurs C d’effectuer une
transition en douceur de la programmation structurée vers la P.O.O. De sa conception jusqu’à
sa normalisation, le langage C++ a quelque peu évolué.

Le C++ est le descendant du langage C. Ces deux langages, bien que semblables au
premier abord, sont néanmoins différents. Le C++ propose de nouvelles fonctionnalités,
comme la programmation orientée objet (POO). Elles en font un langage très puissant qui
permet de programmer avec une approche différente du langage C.

2
2-DE L’ALGORITHME AU C++
Les choses ont ensuite évolué, heureusement. Le clavier et les premiers langages de
programmation sont apparus :
1958 : il y a longtemps, à l'époque où les ordinateurs pesaient des tonnes et faisaient la
taille de votre maison, on a commencé à inventer un langage de programmation appelé
l'Algol.
1960-1970 : ensuite, les choses ont évolué par la création d’un nouveau langage appelé le
CPL, qui évolua lui-même en BCPL, puis pris le nom de langage B.
1970 : puis, un beau jour, on en est arrivé à créer encore un autre langage qu'on a appelé... le
langage C, crée en 1972 par Dennis Ritchie ingénieur américain aux laboratoires Bell.
Ce langage, s'il a subi quelques modifications, reste encore un des langages les plus utilisés
aujourd'hui.

1983 : un peu plus tard, on a proposé d'ajouter des choses au langage C, de le faire évoluer.
Ce nouveau langage, que l'on a appelé "C++", est entièrement basé sur le C. Le langage C++
n'est en fait rien d'autre que le langage C avec plusieurs nouveautés. Il s'agit de concepts de
programmation poussés comme la programmation orientée objet.
Les programmes sont à la base de l'informatique. Ils demandent à votre ordinateur
d'exécuter des actions.
Pour écrire des programmes, on utilise un langage de programmation. Il en existe des
centaines.
Le C++ est un des langages de programmation les plus utilisés dans le monde.
Le C++ est un descendant du C. Il le complète en rajoutant un certain nombre de
possibilités.

3
Le C++ est un langage de bas niveau : il est plus proche du langage machine (le
binaire) et peut parfois être assez complexe.
Le C++ est un langage extrêmement rapide, ce qui en fait le langage de prédilection de
la plupart des jeux vidéo avides de performances.

3-LES LOGICIELS NECESSAIRES POUR PROGRAMMER


Il faut installer certains logiciels spécifiques pour programmer en C++.

3-1-LES OUTILS NECESSAIRES AU PROGRAMMEUR


Il s'agit du compilateur, ce fameux programme qui permet de traduire votre langage C++
en langage binaire.
Il existe plusieurs compilateurs pour le langage C++ :
Visual C++(Windows seulement)
Visual C++ Express
Xcode (Mac OS seulement)
Turbo C++
Code::blocks (Windows, Mac OS, Linux)

3-2-LE STRICT MINIMUM POUR UN PROGRAMMEUR :

Un éditeur de texte pour écrire le code source du programme en C++. En théorie un


logiciel comme le Bloc-Notes sous Windows, ou "vi" sous Linux fait l'affaire. L'idéal,
c'est d'avoir un éditeur de texte intelligent qui colore tout seul le code, ce qui vous permet
de vous repérer dedans bien plus facilement. Voilà pourquoi aucun programmeur sain
d'esprit n'utilise Bloc-Notes.

Un compilateur ("compiler") pour transformer votre source en binaire.

Un débugger pour vous aider à traquer les erreurs dans votre programme (on n'a
malheureusement pas encore inventé le "correcteur", un truc qui corrigerait tout seul nos
erreurs.

4-STRUCTURE GENERALE D’UN PROGRAMME C++


Un programme écrit en C++ se compose généralement de plusieurs fichiers sources. Il y
a deux sortes de fichiers-sources :
-ceux qui contiennent effectivement des instructions ; leur nom possède l’extension
.cpp
-ceux qui contiennent que des déclarations ; leur nom possède l’extension .h (signifiant
‘header’ ou en-tête).
Le C++ offre des possibilités de programmation modulaire : un programme peut être
constitué de plusieurs modules (fichiers).

4
Les instructions sont obligatoirement encapsulées dans des fonctions et il existe une
fonction privilégiée appelée main qui est le point de départ de tout programme.
Le canevas minimal à utiliser un programme C++ se présente ainsi :

5-UN PREMIER EXEMPLE

L’exemple suivant montre un programme simple qui affiche ‘Bonjour’ à l’écran :

La directive #include
On place en général au début du programme un certain nombre d'instructions commençant
par #include. Cette instruction permet d’inclure dans un programme la définition de certains
objets, types ou fonctions. Le nom du fichier peut être soit à l'intérieur des chevrons < et >,
soit entre guillemets : #include <nom_fichier> Inclut le fichier nom_fichier en le cherchant
d'abord dans les chemins configurés, puis dans le même répertoire que le fichier source,
#include "nom_fichier" Inclut le fichier nom_fichier en le cherchant d'abord dans le même
répertoire que le fichier source, puis dans les chemins configurés.

using namespace std;

Cette ligne est un peu plus difficile à comprendre : en effet, on indique par cette ligne
l'utilisation de l'espace de nommage std. Un espace de nommage est un ensemble de classes
dont cout fait partie. Etant donné que nous voulons utiliser l'objet cout, nous indiquons que
l'on utilisera, par défaut, l'espace de nommage std. Pour simplifier, retenons que, dès que l'on
veut utiliser cin ou cout, on doit écrire cette directive.

5
Exemple : Code : C++ - Premier exemple de cin et cout

#include <iostream>
using namespace std;
int main()
{
cout << "Quel âge avez-vous ?" << endl;
int ageUtilisateur(0); //On prépare une case mémoire pour
stocker un entier.
cin >> ageUtilisateur; //On fait entrer un nombre dans cette case.
cout << "Vous avez " << ageUtilisateur << " ans !" << endl;
//Et on l'affiche.
return 0;
}
Je vous invite à tester ce programme. Voici ce que ça donne :

Code : Console - Quel âge avez-vous ?


Quel âge avez-vous ?
22
Vous avez 22 ans !

Il faut également remarquer que les fichiers d'en-tête standard ne sont désormais plus
nommés avec une extension .h (comme iostream.h). Si ces fichiers d'en-tête sont inclus sans
être suivi de la commande using namespace std;, cela ne fonctionnera pas correctement.
Dans certaines versions de C++ , si, lors de la compilation, vous spécifiez un fichier d'en-tête

6
standard avec une extension .h (comme iostream.h), le compilateur utilisera le fichier
"backward" compatible et vous signifiera un avertissement.

Le fichier iostream

Le fichier iostream contient un certain nombre de définitions d’objets intervenant dans les
entrées/sorties du programme, c’est-à-dire dans l’affichage à l’écran ou dans des fichiers. La
définition de cout se trouve dans ce fichier; pour utiliser cout dans notre programme, il faut
inclure au début du programme la ligne suivante :

include <iostream>
Ce fichier est fourni par l’éditeur du compilateur : il s’agit d’un fichier C++ standard.
La fonction main()

Notre programme contient une fonction appelée main : c’est à cet endroit que va
commencer l’exécution du programme : exécuter un programme en C++, c’est exécuter la
fonction main de ce programme. Tout programme en C++ doit donc comporter une fonction
main.

La fonction main apparaît sous la forme suivante :

int main()
{
on place ici une liste d’instructions en C++
}
La liste d’instructions entre accolades est exécutée séquentiellement : on exécute chaque
instruction, dans l’ordre, les unes après les autres.

cout

Il s’agit du flux de sortie du programme (Console Output : sortie console). Ce flux de sortie
est envoyé par défaut vers l’écran. Il va nous servir à afficher des messages à l’écran en
utilisant l'opérateur <<. Cet opérateur à la forme d'une flèche semblant indiquer le sens de
transfert des données (écriture vers la console).

Exemple : cout<<"BONJOUR";
Cette instruction affiche BONJOUR à l’écran.

Un autre exemple :
cout<<endl;
Lorsqu'on envoie endl (End of Line : fin de la ligne) vers l'affichage, on passe à la ligne
suivante.
Il faut également connaître une écriture plus condensée. Au lieu d’écrire en 3 instructions :
cout << "BONJOUR";
cout << endl;
cout << "AU REVOIR";

7
On peut écrire en une seule instruction :

cout << "BONJOUR" << endl << "AU REVOIR";

Cependant, sur certaines implémentations, cette instruction condensée ne compile pas


correctement, car l'implémentation du symbole endl ne permet pas d'utiliser l'opérateur <<
par la suite :
cout << "BONJOUR" << endl;
cout << "AU REVOIR";

Retour de la fonction

La dernière instruction de notre programme est return 0; Elle indique seulement que la
fonction main s'est terminée correctement sans erreur particulière.
Exécution du programme

Lorsqu'on édite notre fichier source, puis compile et enfin exécute notre programme il
s'affiche alors à l'écran : BONJOUR

Remarque

L'ajout de l'instruction système ("PAUSE"); sera parfois nécessaire pour que le


programme ne s'arrête pas immédiatement après s'être ouvert. Cette instruction doit être
ajouté avant l'instruction return 0 ;
Il convient de noter que :
Contrairement au Pascal, le C++ fait la différence entre lettres minuscules et
majuscules : par exemple les x et X représentent deux variables différentes.
Les instructions sont généralement identifiées par le point-virgule. C’est ce caractère
qui marque la fin d’une instruction.
Les espaces (y compris les tabulations et les retors à la ligne) peuvent être utilisés à
volonté avant ou après un séparateur( #< >( ) {} ;……….).On traduit ce fait en disant
que le C++ est un langage au format libre.

8
CHAPITRE 2 :

SYNTAXE ELEMENTAIRE EN
LANGAGE C++

1- INTRODUTION
Avant d’approfondir la programmation C++ nous allons illustrer le principe de la syntaxe
élémentaire d’écriture d’un programme C++.

2- ELEMENTS D’UN PROGRAMME C++


2-1- LES COMMENTAIRES :
Les commentaires sont nécessaires et très simples à faire. Il sert à faciliter la lisibilité du
programme ou tout programme de préférence doit être commenté. Un commentaire est un
texte simple qui n’est pas traité par le compilateur.
Remarque :
Trop de commentaires tuent le commentaire, parce que les choses importantes sont noyées
dans les banalités.
Il existe deux types de commentaires en C++ :
Le premier est symbolisé par une barre oblique et étoile et une autre barre oblique et
étoile (/*…….*/), ces commentaires peuvent s’étendre sur plusieurs lignes.
Le deuxième est symbolisé par deux barres obliques (//…..) qui sont des
commentaires d’une seule ligne.
Exemple :
/* ces commentaires peuvent s’étendre
sur plusieurs lignes.*/
/* indique le début du commentaire et

9
*/indique la fin du commentaire ou le commentaire compris entre ces deux symboles peut
tenir sur plusieurs lignes.
// Commentaires d’une seule ligne.
2-2-LES VARIABLES
Une variable a un nom et un type. Nous savons comment nommer nos variables, voyons
maintenant leurs différents types. L'ordinateur aime savoir ce qu'il a dans sa mémoire, il faut
donc indiquer quel type d'élément va contenir la variable que nous aimerions utiliser. Est-ce
un nombre, un mot, une lettre ? Il faut le spécifier.

Voici donc la liste des types de variables que l'on peut utiliser en C++.

Déclarer une variable


Assez parlé, il est temps d'entrer dans le vif du sujet et de demander à l'ordinateur de nous
prêter un de ses tiroirs. En terme technique, on parle de déclaration de variable.

Il nous faut indiquer à l'ordinateur, le type de la variable que l'on veut, son nom et enfin sa
valeur. Pour se faire, c'est très simple.
On indique les choses exactement dans cet ordre.
TYPE NOM (VALEUR) ;
On peut aussi utiliser la même syntaxe que dans le langage C :
TYPE NOM=VALEUR;
Exemple :

#include <iostream>
using namespace std;
int main()
{
int age(16);
return 0;
}

10
Que se passe-t-il à la ligne 5 de ce programme ?
L'ordinateur voit que l'on aimerait lui emprunter un tiroir dans sa mémoire avec les propriétés
suivantes :
Il peut contenir des nombres entiers.
Il a une étiquette indiquant qu'il s'appelle âge.
Il contient la valeur 16
Le tableau ci-dessous représente les types de variables avec taille et intervalle :

Déclarer sans initialiser


Maintenant que nous avons vu le principe général, il est temps de plonger un petit peu plus
dans les détails. Lors de la déclaration d'une variable, votre programme effectue en réalité
deux opérations successives.

1. Il demande à l'ordinateur de lui fournir une zone de stockage dans la mémoire.


2. Il remplit cette case avec la valeur fournie. On parle alors d'initialisation de la variable.
Ces deux étapes s'effectuent automatiquement et sans que l'on ait besoin de faire.
Il arrive parfois que l'on ne sache pas quelle valeur donner à une variable lors de sa
déclaration. Il est alors possible d'effectuer uniquement l'allocation sans l'initialisation.
Il suffit d'indiquer le type et le nom de la variable sans spécifier de valeur.

TYPE NOM ;

Exemple de déclaration sans initialisation


#include <iostream>
#include <string>
using namespace std;
int main()
{

11
string nomJoueur;
int nombreJoueurs;
bool aGagne; //Le joueur a-t-il gagné ?
return 0;
}
Afficher la valeur d'une variable
Dans le chapitre précédent, vous avez appris à afficher du texte à l'écran. J'espère que vous
vous souvenez encore de ce qu'il faut faire. Oui, c'est bien ça. Il faut utiliser cout et les
chevrons (<<). Parfait. Parce que pour afficher le contenu d'une variable, c'est la même chose.
A la place du texte à afficher, on met simplement le nom de la variable.

Code : C++ - Afficher le contenu d'une variable.


cout << âge;
- Exemple d'affichage
#include <iostream>
using namespace std;
int main()
{
int age(16);
cout << "Votre âge est : ";
cout << age;
return 0;
}
Une fois compilé, ce code affiche ceci à l’écran :
Code : Console - Résultat du code précédent
Votre âge est : 16

2-3- LES DIFFERENTS TYPES DES VARIABLES


Les entiers
Le langage C++ distingue plusieurs types entiers

12
Quelques constants caractères :

Les réels
Un réel est composé :
-d’un signe,
-d’une mantisse,
-d’un exposant,
Un nombre de bits est réservé en mémoire pour chaque élément.
Le langage C++ distingue 2 types de réels :

Types de base et constantes


En C++, les types de base sont :
– bool : booléen 2, peut valoir true ou false,
– char : caractère (en général 8 bits), qui peut aussi être déclaré explicitement signé (signed
char) ou non signé (unsigned char),

13
– int : entier (16 ou 32 bits, suivant les machines), qui possède les variantes short [int] et
long [int], tous trois pouvant également être déclarés non signés (unsigned),
– float : réel (1 mot machine),
– double: réel en double précision (2 mots machines), et sa variante long double (3 ou 4
mots machine),
2-4-Les instructions d’affectation et expression

L’affectation simple

= affectation

Il faut bien noter que le signe = est l’opérateur d’affectation, et non de comparaison ; cela
prête parfois à confusion, et entraîne des erreurs difficiles à discerner. À noter aussi que
l’affectation est une expression comme une autre, c’est-à-dire qu’elle retourne une valeur. Il
est donc possible d’écrire :

a = b = c+2;
ceci revenant à affecter à b le résultat de l’évaluation de c+2, puis à a le résultat de
l’affectation b = c+2, c’est-à-dire la valeur qu’on a donnée à b. Remarquez l’ordre
d’évaluation de la droite vers la gauche.
Exemple :Test de l'affectation d'une variable à une autre
#include <iostream>
using namespace std;
int main()
{
int a(4), b(5); //Déclaration de deux variables.
cout << "a vaut : " << a << " et b vaut : " << b << endl;
cout << "Affectation !"<< endl;
a = b; //Affectation de la valeur de 'b' à 'a'.
cout << "a vaut : " << a << " et b vaut : " << b << endl;
return 0;
}

14
Code : Console(Exécution)
a vaut : 4 et b vaut : 5
Affectation !
a vaut : 5 et b vaut : 5

L’affectation composée qui consiste à associer un opérateur au signe d’affectation de base


‘=’ :
Forme générale :

Variable opérateur =expression


L’expression est équivalente à :
Variable=variable opérateur expression

Exemple :

Opérateurs d’incrémentation et de décrémentation


++ Incrémentation
-- décrémentation
Ces opérateurs, qui ne peuvent être appliqués que sur les types scalaires, peuvent
s’employer de deux manières : en principe, s’ils préfixent une variable, celle-ci sera
incrémentée (ou décrémentée) avant utilisation dans le reste de l’expression ; s’ils la post
fixent, elle ne sera modifiée qu’après utilisation.
Exemple 1 :
A++ ; // A est égale à A+1
A++ ; A=A+1 ; ou A+=1 sont équivalentes.
A-- ; A=A-1 ; ou A-=1 sont équivalentes.

15
Exemple 2 :

2-5-LES OPERATEURS EN C++

En programmation c++, un opérateur est un symbole qui ordonne au compilateur d’effectuer


une opération.

Il existe plusieurs types d’opération :

Opérateur d’opération :

X=a+b ;

Les opérateurs mathématiques :

Il existe cinq opérations l’addition (+), soustraction (-), la multiplication (*), la division (/),
et le modulo (%).Un petit tableau récapitulatif Le tableau ci-dessous résume les opérateurs
mathématiques.

Opération Symbole Exemple


Addition + résultat = a + b;

Soustraction - résultat = a - b;

Multiplication * résultat = a * b;

La division / résultat = a / b;

modulo % résultat = a %b;

Exemple1 :
19.0 / 5.0 vaut 3.8,
19 / 5 vaut 3,
19 % 5 vaut 4.

Exemple 2 :l’addition de deux nombres:

#include <iostream>
using namespace std;
int main()
{

16
double a(0), b(0); //Déclaration des variables utiles
cout << "Bienvenue dans le programme d'addition a+b !" << endl;
cout << "Donnez une valeur pour a : "; //Demande du premier
nombre
cin >> a;
cout << "Donnez une valeur pour b : "; //Demande du deuxième
nombre
cin >> b;
double const resultat(a + b); //On effectue l'opération
cout << a << " + " << b << " = " << resultat << endl; //On
affiche le résultat
return 0;
}

Code : Console (exécution)


Bienvenue dans le programme d'addition a+b !
Donnez une valeur pour a : 123.784
Donnez une valeur pour b : 51.765
123.784 + 51.765 = 175.549

Exemple 3 :

Code : Console (exécution)


3

Nous terminons en donnant quelques fonctions de la bibliothèque standard.

17
Fonctions mathématiques : elles sont déclarées dans <cmath>.il y a notamment les fonctions
suivantes, de paramètre double et de résultat double :

Floor : ([Link]) : partie entière par défaut


Fabs : valeur absolue
Sqrt :racine carrée
Pow : puissance (pow(x,y) renvoie xy)
Exp, log, log10
Sin, cos, tan, asin, acos, atang, sinh, cosh, tanh

Exemple 4 :

Code : Console (exécution)

18
Les opérateurs relationnels

Il en existe six (06) : Égale


à ==, Différent
de ( !=)
Supérieur à (>)
Supérieur ou égale à (>=)
Inférieur à (<)
Inférieur ou égale à (<=)

Exemple :
Int a=27 ; b=19 ;
a==b ; //cette opération donne la valeur False
a<b ; //cette opération donne la valeur True

Les opérateurs d’entrée/sortie

L’opération d’entrée est symbolisée par >> <variable> : lecture au clavier de la


valeur de <variable> et l’opération de sortie est symbolisée par : << <expression>,
affichage à l’écran de la valeur de <expression>.

Exemple :
Int a ;
Cin >>//pour entrer une valeur pour A
A++
Cout <<A ;// afficher le résultat.

Voici un tableau présentant l’ensemble des opérateurs de C++ (certains ne seront exploités
que dans des chapitres ultérieurs) :

19
20
CHAPITRE 3:
STRUCTURES CONDITIONNELLES ET
BOUCLES

1- INTRODUTION
Une structure de contrôle ou instruction de contrôle sert à contrôler le déroulement d’un
traitement.
Un traitement peut s’exécuter de différentes manières :
Séquentiellement (l’un à la suite de l’autre).
Alternativement (soit l’un soit l’autre ou les autres selon une condition fixée).

Alternative simple (if), alternative composée (if else), alternative imbriquée


(if…if else else), alternative multiple (switch)
Répétitivement (en répétant le traitement un nombre fini de fois).
La boucle while, la boucle do while, la boucle for
Le terme instruction désignera indifféremment : une instruction simple (terminée par un
point-virgule), une instruction structurée (choix, boucle) ou un bloc (instructions entre {et}).
Structures de contrôle. Ce nom un peu barbare cache en fait deux éléments que nous verrons
dans ce chapitre :
Les conditions : elles permettent d'écrire dans le programme des règles comme "Si
ceci arrive, alors fais cela".
Les boucles : elles permettent de répéter une série d'instructions plusieurs fois.
2-LES CONDITIONS
Pour qu'un programme soit capable de prendre des décisions, on utilise des conditions dans
le code source (on parle aussi de "structures conditionnelles").
Pour effectuer ces tests, nous utilisons des symboles. Voici le tableau des symboles à
connaître par cœur :

21
Il faut savoir qu'il existe plusieurs types de conditions en C++ pour faire des tests, mais la
plus importante qu'il faut impérativement connaître est sans aucun doute la condition if.
2-1- La condition if
Les conditions permettent de tester des variables pour qu'un programme soit capable de
prendre des décisions.
Syntaxe des traitements alternatifs if
L’alternative simple : if (condition)
Séquence

L’alternative composée : if (condition)


Séquence 1
else
Séquence 2 ;

L’alternative imbriquée : if (condition1)


{
if (condition2)
Séquence 1 ;
else
{
Séquence 3 ;
}
}
else
Séquence 4 ;

Exemple l’alternative simple :

Imaginons qu'on souhaite afficher un message de félicitations si la personne a des enfants.


On va ajouter une condition qui regarde si le nombre d'enfants est supérieur à 0 et qui affiche
un message dans ce cas.

22
#include <iostream>
using namespace std;
int main()
{
int nbEnfants(2);
if (nbEnfants > 0)
{
cout << "Vous avez des enfants, bravo !" << endl;
}
cout << "Fin du programme" << endl;
return 0;
}
Ce code affiche :
Code : Console
Vous avez des enfants, bravo !
Fin du programme

Exemple l’alternative composée :

Pour le même exemple précédant :


else : ce qu'il faut faire si la condition n'est pas vérifiée
Vous souhaitez que votre programme fasse quelque chose de précis si la condition n'est pas
vérifiée ? Vous pouvez utiliser le mot-clé else qui signifie "sinon". On va par exemple
afficher un autre message si la personne n'a pas d'enfants :
#include <iostream>
using namespace std;
int main()
{
int nbEnfants(0);
if (nbEnfants > 0)
{
cout << "Vous avez des enfants, bravo !" << endl;
}
else
{
cout << "Eh bien alors, vous n'avez pas d'enfants ?" <<
endl;
}
cout << "Fin du programme" << endl;
return 0;
}
Ce code affiche :
Code : Console
Eh bien alors, vous n'avez pas d'enfants ?
Fin du programme

23
L’ordinateur lit d'abord la condition du if et se rend compte que la condition est fausse. On
vérifie si la personne a au moins 1 enfant et ce n'est pas le cas. L'ordinateur "saute" tout ce qui
se trouve entre les premières accolades et tombe sur la ligne du else qui signifie "sinon". Il
effectue donc les actions indiquées après le else.

Exemple l’alternative imbriquée :


Il est possible de faire plusieurs tests à la suite. Imaginez qu'on souhaite faire le test suivant :

Si le nombre d'enfants est égal à 0, afficher ce message "[...]"


Sinon si le nombre d'enfants est égal à 1, afficher ce message "[...]"
Sinon si le nombre d'enfants est égal à 2, afficher ce message "[...]"
Sinon, afficher ce message "[...]"
Pour faire tous ces tests un à un dans l'ordre, on va avoir recours à la condition "else if" qui
signifie "sinon si". Les tests vont être lus dans l'ordre jusqu'à ce que l'un d'entre eux soit
vérifié.
Code : C++
#include <iostream>
using namespace std;
int main()
{
int nbEnfants(2);
if (nbEnfants == 0)
{
cout << "Eh bien alors, vous n'avez pas d'enfants ?" <<
endl;
}
else if (nbEnfants == 1)

24
{
cout << "Alors, c'est pour quand le deuxième ?" << endl;
}
else if (nbEnfants == 2)
{
cout << "Quels beaux enfants vous avez la !" << endl;
}
else
{
cout << "Bon, il faut arrêter de faire des gosses maintenant
!" << endl;
}
cout << "Fin du programme" << endl;
return 0;
}

Dans ce cas, nous avons 2 enfants :


L'ordinateur teste d'abord si on en a 0.
Comme ce n'est pas le cas, il passe au premier else if : est-ce qu'on a 1 enfant ? Non
plus !
L'ordinateur teste donc le second else if : est-ce qu'on a 2 enfants ? Oui ! Donc on
affiche le message " Quels beaux enfants vous avez la !".
Si aucune des conditions n'avait été vérifiée, c'est le message du else "Bon, il faut arrêter de
faire des gosses maintenant !" qui se serait affiché.

25
Syntaxe des traitements alternatifs switch

L’alternative switch : switch(séquence )


{
Case valeur 1 :séquence 1 ;
Break ;

.
Case valeur 2 :séquence 2 ;
Case valeur N :séquence N ;
Break ;
Default :séquence ;
}

Exemple l’alternative switch

En théorie, la condition if permet de faire tous les tests que l'on veut. En pratique, il existe
d'autres façons de faire des tests. La condition switch, par exemple, permet de simplifier
l'écriture de conditions qui testent plusieurs valeurs différentes pour une même variable.
Prenez par exemple le test qu'on vient de faire sur le nombre d'enfants :

26
A-t-il 0 enfants ?
A-t-il 1 enfant ?
A-t-il 2 enfants ?
...
On peut faire ce genre de tests avec des if... else if... else, mais on peut faire la même chose
avec une condition switch qui a tendance à rendre le code plus lisible dans ce genre de cas.
Voici ce que donnerait la condition précédente avec un switch :

Code : C++
#include <iostream>
using namespace std;
int main()
{
int nbEnfants(2);
switch (nbEnfants)
{
case 0:
cout << "Eh bien alors, vous n'avez pas d'enfants ?" <<
endl;
break;
case 1:
cout << "Alors, c'est pour quand le deuxieme ?" << endl;
break;
case 2:
cout << "Quels beaux enfants vous avez la !" << endl;
break;
default:
cout << "Bon, il faut arrêter de faire des gosses
maintenant !" << endl;
break;
}
return 0;
}
Cela affiche :
Code : Console
Quels beaux enfants vous avez la !
La forme est un peu différente : on indique d'abord qu'on va analyser la variable
nbEnfants(ligne 9). Ensuite, on teste tous les cas (case) possibles : si ça vaut 0, si ça vaut 1, si
ça vaut 2...
Les break sont obligatoires si on veut que l'ordinateur ne continue pas d'autres tests une fois
qu'il en a vérifié un.

27
Enfin, le default à la fin correspond au else ("sinon") et s'exécute si aucun test précédent n'est
vérifié.
3-LES BOUCLES
Les boucles vous permettent de répéter les mêmes instructions plusieurs fois dans votre
programme. Le principe est le suivant :

L'ordinateur lit les instructions de haut en bas (comme d'habitude)


Puis, une fois arrivé à la fin de la boucle, il repart à la première instruction
Il recommence alors à lire les instructions de haut en bas...
... Et il repart au début de la boucle.
Les boucles sont répétées tant qu'une condition est vraie. Par exemple on peut faire une
boucle qui dit : "Tant que l'utilisateur donne un nombre d'enfants inférieur à 0, redemander le
nombre d'enfants"...
Il existe 3 types de boucles à connaître :
for
while
do ... while

La boucle FOR

Ce type de boucle, que l'on retrouve fréquemment, permet de condenser :


Une initialisation
Une condition
Une incrémentation
Syntaxe :
for (expr1 ;expr2 ;expr3) instr

28
Voici un exemple concret qui affiche des nombres de 0 à 9 :
Code : C++

#include <iostream>
using namespace std;
int main()
{
int compteur(0);
for (compteur = 0 ; compteur < 4 ; compteur++)
{
cout << compteur << endl;
}
return 0;
}

Ce code affiche :
Code : Console
0
1
2
3
On retrouve sur la ligne du for les 3 instructions que je vous ai indiquées :
Une initialisation (compteur = 0) : la variable compteur est mise à 0 au tout début de la
boucle. Notez que ça avait été fait juste la ligne au-dessus donc ce n'était pas vraiment
nécessaire ici.
Une condition (compteur < 4) : on vérifie que la variable compteur est inférieure à 4 à
chaque nouveau tour de boucle.
Une incrémentation (compteur++) : à chaque tour de boucle, on ajoute 1 à la variable
compteur ! Voilà pourquoi on voit s'afficher à l'écran des nombres de 0 à 3.
La boucle while
Syntaxe:
while (condition)
{
/* Instructions à répéter */
}

29
Tout ce qui est entre accolades sera répété tant que la condition est vérifiée.
Exemple de la boucle while
On redemande le nombre d'enfants à l'utilisateur tant que celui-ci est inférieur à 0. Ce genre
de boucle permet de s'assurer que l'utilisateur rentre un nombre correct.

Code : C++
#include <iostream>
using namespace std;
int main()
{
int nbEnfants(-1); // Nombre négatif pour pouvoir rentrer dans
la boucle
while (nbEnfants < 0)
{
cout << "Combien d'enfants avez-vous ?" << endl;
cin >> nbEnfants;
}
cout << "Merci d'avoir indique un nombre d'enfants correct. Vous
en avez " << nbEnfants << endl;
return 0;
}
Code : Console
Combien d'enfants avez-vous ?
-3
Combien d'enfants avez-vous ?
-5
Combien d'enfants avez-vous ?
2
Merci d'avoir indiqué un nombre d'enfants correct. Vous en avez 2

30
Tant que vous mettrez un nombre négatif, la boucle recommencera. En effet, elle teste while
(nbEnfants < 0) c'est-à-dire "Tant que le nombre d'enfants est inférieur à 0". Dès que le
nombre devient supérieur ou égal à 0, la boucle s'arrête et le programme continue après
l'accolade fermante.
La boucle do while
Syntaxe:
Cette boucle est très similaire à la précédente... si ce n'est que la condition n'est analysée
qu'à la fin. Cela signifie que le contenu de la boucle sera toujours lu au moins une première
fois.
do
{
/* Instructions */
} while (condition);

Reprenons le code de l’exemple précédent et utilisons cette fois un do ... while :


Code : C++
#include <iostream>
using namespace std;
int main()
{
int nbEnfants(0);
do
{
cout << "Combien d'enfants avez-vous ?" << endl;
cin >> nbEnfants;
} while (nbEnfants < 0);
cout << "Merci d'avoir indique un nombre d'enfants correct. Vous
en avez " << nbEnfants << endl;
return 0;
}

31
Le principe est le même, le programme a le même comportement. Le gros intérêt du do ...
while est qu'on s'assure que la boucle sera lue au moins une fois.
D'ailleurs, du coup, il n'est pas nécessaire d'initialiser nbEnfants à -1 (c'est le principal
avantage que procure cette solution). En effet, ici le nombre d'enfants est initialisé à 0
(comme on a l'habitude de faire), et comme la condition n'est testée qu'après le premier
passage de la boucle, les instructions sont bien lues au moins une fois.
Exemple :
Soit une équation du second degré ax2+bx+c=0
a,b,c sont des nombres réels.
Ecrire un programme qui permet de résoudre cette équation.
Pour trouver les solutions si elles existent il faut :
1-verifier si a=0 dans ce cas la solution est x=-c/b
2-calculer le discriminant D=b2-4ac
Si D=0 alors il existe une solution double x0=-b/2a
Si D>0 alors il existe deux solutions x1=(-b-√ )/2a
X2=(-b+√ )/2a
Si D<0 alors pas de solutions réelles
Code c++ :

#include <iostream>
#include <math.h>// pour l’utilisation de la fonction sqrt
using namespace std;
int main()
{
float a,b,c,x0,x1,x2,D;
cout<<"resolution d’une equation du second degré \n";
cout<<"introduire la valeur de a \n";
cin>>a;
cout<<"introduire la valeur de b \n";
cin>>b;
cout<<"introduire la valeur de c \n";
cin>>c;
if (a==0 && b!=0)
{

32
Cout<< "on obtient une équation du premier degré \n" ;
X0=-c/b ;
Cout<< "la solution de l’équation est : "<<x0<<" \n" ;
}
Else
{
D=(b*b)-4*a*c ;
If (D==0)
{
X0=-b/(2*a);
Cout<< "la solution double de l’équation est : "<<x0<<" \n" ;
}
Else
If (D>0)
{
X1=(-b-sqrt(D))/(2*a) ;
X2=(-b+sqrt(D))/(2*a) ;
Cout<< "deux solutions distinctes de l’équation \n" ;
Cout<< "x1= "<<x1<<" \n" ;
Cout<< "x2= "<<x2<<" \n" ;
}
Else
{
Cout<< "pas de solutions réelles \n" ;
}
}
return 0;
}

33
CHAPITRE 4:
ENTREES / SORTIES

1-INTRODUCTION
Ce chapitre présente les opérations Entrées / Sorties les plus courantes et les plus requises
pour la programmation C ++.
En C++, les entrées-sorties reposent sur les notions de flot et de sur définition d’opérateur que
nous n’aborderons qu’ultérieurement. Les flux d'entrée / sortie de la bibliothèque standard
C++ constituent sans doute l'une des applications les plus intéressantes de la surcharge des
opérateurs. Comme nous allons le voir, la surcharge des opérateurs << et >> permet d'écrire et
de lire sur ces flux de manière très intuitive. Il ne serait pas judicieux cependant d’attendre
que vous ayez étudié ces différents points pour commencer à écrire des programmes
complets. C’est pourquoi dans ce chapitre nous vous présentons ces possibilités d’entrées-
sorties, de manière assez informelle, en nous limitant à ce que nous nommons l’aspect
conversationnel, à savoir :
o la lecture sur l’entrée standard ;
o l’écriture sur la sortie standard.

2-Généralité sur les flots

Un programme qui n'interagit pas du tout avec l'extérieur ne peut présenter aucun intérêt. Il
faut au minimum que le programme puisse écrire un résultat à l'écran ou dans un fichier. Dans
ce but, la technique des flux est utilisée.

34
Définition d’un flux : Un flux est un transfert d’informations, partant d’un émetteur, jusqu’à
un récepteur, qui consomme ces informations (ce flux).
Les entrées et sorties en C++ se font toujours par l'intermédiaire de flots (ou flux), qu'on peut
considérer comme des canaux
- recevant de l'information dans le cas d'un flot de sorties.
- fournissant l'information dans le cas d'un flot d'entrées.
Le flot de sorties standard est cout. Ce flot est connecté par défaut à l'écran.
Le flot d'entrées standard est cin. Ce flot est connecté par défaut au clavier.

Les opérateurs de manipulation des flots, qui permettent le transfert de l'information sont
- << qui permet l'écriture sur un flot de sorties
- >> qui permet la lecture sur un flot d'entrées

En effet, la bibliothèque standard C++ définit dans l'en-tête Iostream des classes
extrêmement puissantes permettant de manipuler les flux d'entrée / sortie. Ces classes
réalisent en particulier les opérations d'entrée / sortie de et vers les périphériques d'entrée et
les périphériques de sortie standards (généralement, le clavier et l'écran). La programmation
des E/S en C++ est particulièrement facile pour la plupart des besoins du programmeur. En
effet, avec les 2 opérateurs '<<' et '>>' et les 2 mots 'cin' et 'cout' on gère les dialogues avec
le clavier et l’écran ; et avec 2 mots supplémentaires, 'ofstream' et 'ifstream' on accède aux
fichiers, car pour ces deux classes, l'ouverture est réalisée dans le constructeur et la fermeture
dans le destructeur.

La structuration des instructions sur 'flots en mémoire':

35
o istrstream qui dérive de istream
o ostrstream qui dérive de ostream

Signalons les quatre flots mis à la disposition du programmeur, déclarés dans iostream.h:
extern istream_withassign cin; // Entrée par défaut (assignée au clavier)
extern ostream_withassign cout; // Sortie par défaut (assigné à la console)
extern ostream_withassign cerr; // Sortie par défaut des erreurs (idem)
extern ostream_withassign clog; // Sortie par défaut des journaux (idem)

Voici un petit schéma récapitulatif :

3-INSTRUCTIONS D’ENTREE/SORTIE (I/O)

Les entrées sont les données que l’utilisateur fournit à un programme durant l’exécution, par
l’intermédiaire du clavier ou d’un fichier. Les sorties sont les résultats que le programme
fournit à l’utilisateur durant l’exécution, par l’intermédiaire de l’écran ou d’un fichier. On
utilise les instructions d’entrée-sortie du C++ parce qu’elles sont plus simples que celles du C.
Il faut, dans tous les cas, ajouter au début du fichier contenant le programme :

#include using namespace std;

Namespaces.

Un problème classique en C est le fait que toutes les déclarations globales partagent le
même espace de nommage. Cela peut poser problème si, par exemple, vous souhaitez
utiliser deux bibliothèques déclarant une fonction max(). Le C++ utilise un système
d’espace de nommage (namespace) pour éviter cela. Toutes les fonctions du C++ sont
donc inclues dans le namespace std. En pratique, pour accéder à un élément de la
bibliothèque standard, il faut ajouter std:: devant pour signaler que l’on cherche à accéder
à un élément du namespace std. Lorsque un namespace est fréquemment utilisé dans un

36
fichier, il est possible d’ajouter la déclaration using namespace std; pour éviter d’avoir à
ajouter std:: partout. Cependant, il ne faut jamais faire cela dans un fichier header !

Pour pouvoir demander à l’ordinateur d’exécuter des fonctions de (i/o)


– Il faut inclure dans le programme le fichier d’entête C++ <iostream>

#include<iostram>

3-1-LIRE AU CLAVIER

Le flux cin
Syntaxe :
cin >> valeur1>> ... >> valeurn;
-cin est le flux d’entrée du clavier
– ">>" permet d’orienter les valeurs tapées dans le clavier vers les variables valeuri
– cin permet de lire des valeurs de tous les types.
En pratique :
– Lors de l’exécution d’un programme, si on rencontre une instruction cin, l’exécution
s’arrête en attente de la saisie des valeurs dans le clavier. Selon la syntaxe précédente, il
faudra saisir n valeurs val i espacées par des espaces, des tabulations ou des sauts de ligne. Il
faudra terminer la saisie par un saut de ligne.
Le programme va affecter à chaque variable valeuri la valeur val i:(valeuri=vali)

Exemples
Code c++:

#include <iostream.h>

int main ()
{
int n;
float x;
char t[80+1];
do
{
cout << "donner un entier, une chaîne et un flottant : ";
cin >> n >> t >> x;
cout << "merci pour " << n << ", " << t << " et " << x << "\n";
}
while (n);
return 0;
}

Exécution:

37
donner un entier, une chaîne et un flottant : 15 bonjour 8.25
merci pour 15, bonjour et 8.25
donner un entier, une chaîne et un flottant : 15
bonjour
8.25
merci pour 15, bonjour et 8.25
donner un entier, une chaîne et un flottant : 0 bye 0
merci pour 0, bye et 0

3-2-AFFICHER à L’ECRAN

Le flux cout
Pour écrire le contenu de n'importe quelle variable a l'écran, on utilise l'objet cout qui est une
instance de la classe ostream_withassign définie dans la libraire de flux d'entrée-sortie
iostream (io signifie input-output, stream signifie flux). Le flux cout doit être vu comme un
« tube » (un pipe en anglais) qui relie le programme avec l'écran.
Pour afficher le contenu d'une variable à l'écran, on procède comme suit :
Syntaxe :
cout << expr1<< ... << exprn<< endl;

– cout est le flux d’affichage de l’écran de la console

– "<<" permet d’orienter les expressions expri vers cout;

– endl permet d’afficher un saut de ligne si besoin, elle est optionnelle

– cout permet d’afficher les expressions de tous les types.

– Selon cette syntaxe, l’expression expr1puis l’expression expr2,jusqu’à l’expression expr n


vont s’afficher à la console l’une collée à l’autre, puis un saut de ligne va être affiché.

Exemple 1

#include <iostream.h> // indispensable pour utiliser cout

int main()
{
cout << "bonjour"; // équivalent à printf("bonjour"); du langage C
return 0;
}

- cout est un flot de sorties prédéfini associé à la sortie standard (stdout du C).
- << est un opérateur dont l’opérande de gauche (cout) est un flot et l’opérande de droite, une
expression de type quelconque.

L’instruction "cout << …" précédente peut être interprétée comme ceci : le flot cout reçoit la

38
valeur "bonjour".
Exemple 2

#include <iostream.h>

int main()
{
int n = 19;
char c = 'b';
char *ch = "souad";
double x = 2018.3456789;

cout << "valeur de n : " << n << "\n";


cout << "valeur de c : " << c << "\n";
cout << "chaîne ch : " << ch << "\n";
cout << "valeur de x : " << x << "\n";
return 0;
}

L’exécution devrait donner :

valeur de n : 19
valeur de c : b
chaîne ch : souad
valeur de x : 2018.3456789
4-CAS DES CHAINES DE CARACTERES
Les chaines de caractères sont un groupe de lettres et permettent de représenter des mots,
phrases, etc. Une chaine de caractère est un tableau de char dont la dernière valeur est égale la
valeur 0 (zéro). En C++ il existe deux manières de gérer les chaines de caractères
_ un tableau de caractère : char ch[50];
_ un objet : stringst;

Exemple :Voici des exemples d’utilisation de chaines de caractères.


Code c++ :

#include<iostream>
usingnamespacestd;

int main(intargc,char*argv[])
{
inti;

cout<<"ChainedeCaracteres:";
charch[50];
cin>>ch;

39
cout<<"Lachaineest:"<<ch<<endl;
for(i=0;ch[i]!=0 ;i++) //jusqu’alavaleur0
cout<<"’"<<ch[i] <<"’";
cout<<endl;

cout<<"String:";
stringst; cin>>st;
cout<<"Lestringest:"<<st<<endl;
for(i=0;i<[Link]() ;i++) //permet de connaitre le nombre de caracteres
cout<<"’"<<st[i] <<"’";
cout<<endl;
}
Si on souhaite demander à l’utilisateur d’entrer une chaine comportant des espaces,
l’utilisation du code suivant est nécessaire (même recommandé dans de nombreux cas pour
éviter les failles de type buffer-overflow).
charch[50];
[Link](ch,50);
Avec un object string ceci est possible grâce au code suivant (utilisation de la fonction globale
getline: ajouter #include<string> ):
stringstr;
getline(cin,str);

40
CHAPITRE 5:

POINTEURS ET TABLEAUX

1- TABLEAUX
Ils existent deux sortes de tableaux différents. Ceux dont la taille est fixée les tableaux
statiques et ceux dont la taille peut varier, les tableaux dynamiques.
1-1- Tableau statique
Un tableau est une zone continue en mémoire, constituée de cellules contenant des données
toutes de même type ou est un ensemble ordonné d’une taille fixe de plusieurs variables du
même type.
Forme de la déclaration d’un tableau statique

<type> <nom> [<taille>];


où :
<type> est le type des ´éléments du tableau,
<nom> est le nom du tableau,
<taille> est une constante entière ´égale au nombre d’éléments du tableau.
On indique le type, puis le nom choisi et enfin la taille du tableau entre crochets. Voyons ça
avec un exemple.
Exemples :
Code : C++: tableau
#include <iostream>
using namespace std;
int main()
{
int meilleurScore[5]; //Declare un tableau de 5 entiers
double anglesTriangle[3]; //Declare un tableau de 3 double
return 0;

41
}

On retrouve nos deux zones mémoires avec leurs étiquettes, mais cette fois, chaque zone est
découpée en cases. Trois cases pour le tableau anglesTriangle et cinq cases pour le tableau
meilleurScore. Pour l'instant toutes ces cases ne sont pas initialisées. Leur contenu est donc
quelconque.

Accéder aux éléments d'un tableau

Pour accéder à une case on utilise la syntaxe nomDuTableau[numeroDeLaCase]. Il y a juste


une petite subtilité, la première case possède le numéro 0 et pas 1. Tout est en quelque sorte
décalé de 1. Pour accéder à la 3e case de meilleurScore et y écrire une valeur, il faudra donc
écrire :
Code : C++
meilleurScore[2] = 5;
En effet,3-1=2 , la 3e case possède le numéro 2. Si je veux remplir mon tableau des meilleurs
scores comme dans l'exemple initial, je peux donc écrire :

Code : C++ - Remplissage d'un tableau

int const nombreMeilleursScores(5); //La taille du tableau


int meilleursScores[nombreMeilleursScores]; //Declaration du
tableau
meilleursScores[0] = 118218; //Remplissage de la premiere case
meilleursScores[1] = 100432; //Remplissage de la deuxiemecase
meilleursScores[2] = 87347; //Remplissage de la troisieme case
meilleursScores[3] = 64523; //Remplissage de la quatrieme case

42
meilleursScores[4] = 31415; //Remplissage de la cinquieme case

Parcourir un tableau
Le gros point fort des tableaux, c'est qu'on peut les parcourir en utilisant une boucle. On peut
ainsi effectuer une action sur chacune des cases d'un tableau l'une après l'autre. Par exemple
afficher le contenu des cases.
On connaît à priori le nombre de cases du tableau, on peut donc utiliser une boucle for. Nous
allons pouvoir utiliser la variable i de la boucle pour accéder au ième élément du tableau.
C'est fou, on dirait que c'est fait pour !

Code : C++ - Parcourir un tableau

int const nombreMeilleursScores(5); //La taille du tableau


int meilleursScores[nombreMeilleursScores]; //Declaration du
tableau
meilleursScores[0] = 118218; //Remplissage de la premiere case
meilleursScores[1] = 100432; //Remplissage de la deuxiemecase
meilleursScores[2] = 87347; //Remplissage de la troisieme case
meilleursScores[3] = 64523; //Remplissage de la quatrieme case
meilleursScores[4] = 31415; //Remplissage de la cinquieme case
for(int i(0); i<nombreMeilleursScores; ++i)
{
cout << meilleursScores[i] << endl;
}
La variable i va prendre successivement les valeurs 0,1,2,3 et 4. Ce qui veut dire que ce seront
les valeurs de meilleursScores[0] puis meilleursScores[1] etc. qui seront envoyées dans
cout.
Exemple1 :
Un programme qui calcule la moyenne de notes.

Code : C++ - Calcul de la moyenne des notes


#include <iostream>
using namespace std;
int main()
{
int const nombreNotes(6);
double notes[nombreNotes];
notes[0] = 12.5;
notes[1] = 19.5; //Bieeeen !
notes[2] = 6.; //Pas bien !
notes[3] = 12;
notes[4] = 14.5;

43
notes[5] = 15;
double moyenne(0);
for(int i(0); i<nombreNotes; ++i)
{
moyenne += notes[i]; //On additionne toutes les notes
}
//En arrivant ici, la variable moyenne contient la somme des
notes (79.5)
//Il ne reste donc qu'a divisé par le nombre de notes
moyenne /= nombreNotes;
cout << "Votre moyenne est : " << moyenne << endl;
return 0;
}
Code : Console : Exécution
Votre moyenne est : 13.25
Exemple 2 :
Code : C++
#include <iostream>
using namespace std;
int main()
{
int t[10], i;
for(i=0; i<10; i++)
{
cout << "Tapez la valeur numero " << i << " : ";
cin >> t[i];
}
for(i=0; i<10; i++) t[i] = t[i]+1;
for(i=0; i<10; i++) cout << "La valeur numero " << i <<" est : "<< t[i] <<endl;
return 0;
}
• Explications
• Dans ce programme, nous allons tout d'abord saisir une à une le contenu des 10 cases d'un
tableau t.
• Ensuite nous allons effectuer un traitement simple sur ce tableau : nous allons incrémenter
de 1 le contenu de
chaque case.
• Finalement, nous afficherons le contenu final de chaque case du tableau.
• Dans ce programme, nous commençons par définir un tableau t de 10 cases de type entier.
La première case de
ce tableau sera t[0],… et la dernière t[9].
• La première boucle for permet de saisir une à une les cases du tableau : for(i=0;i<10;i++) {
cout<<"Tapez la

44
valeur numero "<<i<<" : "; cin>>t[i]; } remarque : la première valeur de i pour laquelle le
corps du for sera
effectué sera i=0, la dernière i=9
• for(i=0;i<10;i++)t[i]=t[i]+1;
Dans cette boucle for, on augmente de 1 le contenu de chaque case du tableau.
• for(i=0;i<10;i++) cout<<"La valeur numero "<<i<<" est : " <<t[i]<<endl;
On affiche une à une le contenu des cases du tableau.
• Exécution
Tapez la valeur numero 0 : 5
Tapez la valeur numero 1 : 2
Tapez la valeur numero 2 : 50
Tapez la valeur numero 3 : 10
Tapez la valeur numero 4 : 20
Tapez la valeur numero 5 : 60
Tapez la valeur numero 6 : 80
Tapez la valeur numero 7 : 90
Tapez la valeur numero 8 : 10
Tapez la valeur numero 9 : 10
La valeur numero 0 est 6
La valeur numero 1 est 3
La valeur numero 2 est 51
La valeur numero 3 est 11
La valeur numero 4 est 21
La valeur numero 5 est 61
La valeur numero 6 est 81
La valeur numero 7 est 91
La valeur numero 8 est 11
La valeur numero 9 est 11

Exemple 3:
Voici un programme qui permet d’entrer des entiers dans un vecteur de 6 éléments et de
calculer la somme de ses éléments ?
Code C++
#include <iostream>
using namespace std;
int main()
{
Int tab[6];

45
Int i;
Int som=0;
For(i=1;i<=5;i++)
{
cout<<"introduire un entier dans le tableau,tab["<<i<<"]=";
cin>>tab[i];
som=som+tab[i];
}
cout<<"la somme des éléments du tableau est "<<som<<"\n";
return 0;
}

1-2- Les tableaux dynamiques


Déclarer un tableau dynamique

La première différence se situe au tout début de votre programme. Il faut ajouter la ligne
#include <vector> pour utiliser ces tableaux.

La deuxième grosse différence se situe dans la manière de déclarer un tableau. On utilise la


syntaxe :

vector<type> nom(VectTaille);
Par exemple pour un tableau de 5 entiers, on écrit :

Code : C++
#include <iostream>
#include <vector> //Ne pas oublier !
using namespace std;
int main()
{
vector<int> tableau(5);
return 0;
}

Accéder aux éléments d'un tableau

La déclaration était très différente des tableaux statiques. Par contre là, c'est exactement
identique. On utilise à nouveau les crochets et la première case possède aussi le numéro 0.
Exemple :
Code : C++ - Remplissage d'un tableau

46
int const nombreMeilleursScores(5); //La taille du tableau
vector<int> meilleursScores(nombreMeilleursScores); //Déclaration
du tableau
meilleursScores[0] = 118218; //Remplissage de la première case
meilleursScores[1] = 100432; //Remplissage de la deuxième case
meilleursScores[2] = 87347; //Remplissage de la troisième case
meilleursScores[3] = 64523; //Remplissage de la quatrième case
meilleursScores[4] = 31415; //Remplissage de la cinquième case

Changer la taille

Entrons maintenant dans le vif du sujet. Faire varier la taille d'un tableau. Commençons par
ajouter des cases à la fin d'un tableau. Il faut utiliser push_back(). On écrit le nom du tableau,
suivi d'un point et du mot push_back avec entre parenthèses la valeur qui va remplir la
nouvelle case.
Code : C++
vector<int> tableau(3,2); //Un tableau de 3 entiers valant tous 2
tableau.push_back(8); //On ajoute une 4ème case au tableau. Cette case contient la valeur .

Une case supplémentaire a été ajoutée au bout du tableau. Tout se fait de manière
automatique.
On peut supprimer la dernière case d'un tableau en utilisant la fonction pop_back() de la
même manière que push_back(). Sauf qu'il n'y a rien à mettre entre les parenthèses.
Code : C++
vector<int> tableau(3,2); //Un tableau de 3 entiers valant tous 2
tableau.pop_back(); //Et hop ! Plus que 2 cases.
tableau.pop_back(); //Et hop ! Plus qu'une case.

47
Il nous reste quand même un petit problème à régler. Comme la taille peut changer, on ne sait
pas combien d'éléments un tableau contient de manière certaine. Heureusement, il y a une
fonction pour ça. C'est la fonction size(). En faisant [Link](), on récupère un entier
correspondant au nombre d'éléments de tableau.

Code : C++
vector<int> tableau(5,4); //Un tableau de 5 entiers valant tous 4
int const taille([Link]()); //Une variable pour contenir la taille du tableau
//La taille peut varier mais la valeur de cette variable ne changera pas.
//On utilise donc une constante.
//A partir d'ici, la constante 'taille' vaut donc 5

Exemple : du calcul des moyennes


Code : C++ - Calcul de moyenne en utilisant vector
#include <iostream>
#include <vector> //Ne pas oublier !!
using namespace std;
int main()
{
vector<double> notes; //Un tableau vide
notes.push_back(12.5); //On ajoute des cases avec les notes
notes.push_back(19.5);
notes.push_back(6);
notes.push_back(12);
notes.push_back(14.5);
notes.push_back(15);
double moyenne(0);
for(int i(0); i<[Link](); ++i) //On utilise [Link]()
pour la limite de notre boucle
{
moyenne += notes[i]; //On additionne toutes les notes
}
moyenne /= [Link](); //On utilise a nouveau [Link]()
pour obtenir le nombre de notes
cout << "Votre moyenne est : " << moyenne << endl;
return 0;

1-3- Tableau multi-dimensionnel


Déclaration d'un tableau multi-dimensionnel

48
Pour déclarer un tel tableau, il faut indiquer les dimensions les unes après les autres entre
crochets.

type nomTableau[tailleX][tailleY]

Exemple :

Donc pour reproduire le tableau du schéma, on doit déclarer le tableau suivant.

int tableau[5][4];

Ou encore mieux, en déclarant des constantes.


Code : C++ - Déclaration du tableau du schéma
int const tailleX(5);
int const tailleY(4);
int tableau[tailleX][tailleY];

Accéder aux éléments

Pour accéder à une case de notre grille, il faut indiquer la position en X et en Y de la case
voulue. Par exemple tableau[0][0] accède à la case en-bas à gauche de la grille. tableau[0][1]
correspond à celle qui se trouve juste en-dessus, alors que tableau[1][0] se situe directement à
sa droite.

2- 2-Les pointeurs
2-2-1- Adresse
Lorsque l'on déclare une variable, l'ordinateur nous prête une place dans sa mémoire et y
accroche une étiquette portant le nom de la variable.
Code : C++
int main()

49
{
int ageUtilisateur(16);
return 0;
}
On pouvait donc représenter la mémoire utilisée dans ce programme sur le schéma suivant :

La mémoire d'un ordinateur est réellement constituée de "cases". Il y en a même énormément.


Plusieurs milliards sur un ordinateur récent ! Il faut donc un système pour que l'ordinateur
puisse retrouver les cases dont il a besoin.
Chaque "case" possède un numéro unique, son adresse.

L'important est que chaque variable possède une seule adresse. Et chaque adresse correspond
à une seule variable. L'adresse est donc un deuxième moyen d'accéder à une variable. On peut
accéder à la case jaune du schéma par deux chemins différents :
On peut passer par son nom (l'étiquette) comme on sait déjà le faire...
Mais on peut aussi accéder à la variable grâce à son adresse (son numéro de case)..
On pourrait alors dire à l'ordinateur "Affiche moi le contenu de l'adresse 53768"

50
Afficher l'adresse
En C++, le symbole pour obtenir l'adresse d'une variable est l'esperluette (&). Si je veux
afficher l'adresse de la variable ageUtilisateur, je dois donc écrire &ageUtilisateur.
Essayons.

Code : C++
#include <iostream>
using namespace std;
int main()
{
int ageUtilisateur(16);
cout << "L'adresse est : " << &ageUtilisateur << endl; //
Affichage de l'adresse de la variable
return 0;
}
Code : Console
L'adresse est : 0x22ff1c
L'esperluette veut dire "adresse de". Donc cout << &a; se traduit en français par "Affiche
l'adresse de la variable a".
2-2-2- Les pointeurs définition
Un pointeur est une variable qui contient l'adresse d'une autre variable.
Une variable pointeur est destinée à manipuler des adresses d’informations d’un type donné.
Déclarer un pointeur
Pour déclarer un pointeur, il faut, comme pour les variables, deux choses :
Un type
Un nom
Pour le nom, il n'y a rien de particulier à signaler. Les mêmes règles que pour les variables
s'appliquent. Ouf !
Le type d'un pointeur a une petite subtilité. Il faut indiquer quel est le type de variable dont on
veut stocker l'adresse et ajouter une étoile (*).
Exemple :
Code : C++ - Déclaration d'un pointeur
int *pointeur;
Ce code déclare un pointeur qui peut contenir l'adresse d'une variable de type int.
Exemple :
Code : C++ - Déclaration de pointeurs
double *pointeurA; //Un pointeur qui peut contenir l'adresse d'un nombre a virgule
unsigned int *pointeurB; //Un pointeur qui peut contenir l'adresse d'un nombre entier positif
string *pointeurC; //Un pointeur qui peut contenir l'adresse d'une chaîne de caractères

51
vector<int> *pointeurD; //Un pointeur qui peut contenir l'adresse d'un tableau dynamique de
nombres entiers
int const *pointeurE; //Un pointeur qui peut contenir l'adresse d'un nombre entier constant

Stocker une adresse

Maintenant qu'on a la variable, il n'y a plus qu'à mettre une valeur dedans. Vous savez déjà
comment obtenir l'adresse d'une variable (rappelez-vous du &). Allons-y !

Code : C++
int main()
{
int ageUtilisateur(16); //Une variable de type int.
int *ptr(0); //Un pointeur pouvant contenir
l'adresse d'un nombre entier.
ptr = &ageUtilisateur; //On met l'adresse de 'ageUtilisateur'
dans le pointeur 'ptr'.
return 0;
}
La ligne 6 est celle qui nous intéresse. Elle écrit l'adresse de la variable ageUtilisateur dans le
pointeur ptr. On dit alors que le pointeur ptr pointe sur ageUtilisateur.

Afficher l'adresse
Comme pour toutes les variables, on peut afficher le contenu d'un pointeur.
Code : C++
#include <iostream>

52
using namespace std;
int main()
{
int ageUtilisateur(16);
int *ptr(0);
ptr = &ageUtilisateur;
cout << "L'adresse de 'ageUtilisateur' est : " <<
&ageUtilisateur << endl;
cout << "La valeur de pointeur est : " << ptr << endl;
return 0;
}
Code : Console
L'adresse de 'ageUtilisateur' est : 0x2ff18
La valeur de pointeur est : 0x2ff18

Accéder à la valeur pointée

Le but des pointeurs est d’accéder à une variable sans passer par son nom. Voici
comment faire. Il faut utiliser l'étoile (*) sur le pointeur pour afficher la valeur de la
variable pointée.

Code : C++
int main()
{
int ageUtilisateur(16);
int *ptr(0);
ptr= &ageUtilisateur;
cout << "La valeur est : " << *ptr << endl;
return 0;
}
En faisant cout << *ptr, le programme va effectuer les étapes suivantes :
1. Aller dans la case mémoire nommée ptr.
2. Lire la valeur enregistrée.
3. "Suivre la flèche" pour aller à l'adresse pointée.
4. Lire la valeur stockée dans la case.
5. Afficher cette valeur. Ici, ce sera bien sûr 16 qui sera affiché.
En utilisant l'étoile, on accède à la valeur de la variable pointée. C'est ce qui s'appelle
déréférencer un pointeur.

L'allocation dynamique
Pour demander manuellement une case dans la mémoire, il faut utiliser l'opérateur new.

53
new va demander une case à l'ordinateur et renvoyer un pointeur pointant vers cette case.
Code : C++
int *pointeur(0);
pointeur = new int;
*pointeur = 2; //On accède à la case mémoire pour en modifier la Valeur
La deuxième ligne demande une case mémoire pouvant stocker un entier et l'adresse de cette
case est stockée dans le pointeur.
Une fois allouée manuellement, la variable s'utilise comme n'importe quelle autre. On doit
juste se rappeler qu'il faut y accéder par le pointeur en le déréférençant.
La case sans étiquette est maintenant remplie. La mémoire est donc dans l'état suivant :

Libérer la mémoire
Une fois que l'on a plus besoin de la case mémoire, il faut la rendre à l'ordinateur. Cela se fait
via l'opérateur delete.

Code : C++
int *pointeur(0);
pointeur = new int;
delete pointeur; //On libère la case mémoire
La case est alors rendue à l'ordinateur qui pourra l'utiliser pour autre chose. Le pointeur, lui,
existe toujours. Et il pointe toujours sur la case mais vous n'avez plus le droit de l'utiliser.

54
L'image est très parlante. Si l'on suit la flèche, on arrive sur une case qui ne nous appartient
pas. Il faut donc impérativement empêcher ça. Imaginez que cette case soit soudainement
utilisée par un autre programme ! Vous risqueriez de modifier les variables de cet autre
programme.
Il est donc essentiel de supprimer cette "flèche" en mettant le pointeur à l'adresse 0 après
avoir utilisé delete. Ne pas le faire est une source très courante de plantage des programmes.

Code : C++
int *pointeur(0);
pointeur = new int;
delete pointeur; //On libère la case mémoire
pointeur = 0; //On indique que le pointeur ne pointe vers plus rien

Exemple
Terminons cette section avec un exemple complet : un programme qui demande son âge à
l'utilisateur et qui l'affiche en utilisant un pointeur.
Code : C++
#include <iostream>
using namespace std;
int main()
{
int* pointeur(0);
pointeur = new int;
cout << "Quel est votre age ? ";
cin >> *pointeur; //On écrit dans la case mémoire pointée par
le pointeur 'pointeur'
cout << "Vous avez " << *pointeur << " ans." << endl; //On
utilise à nouveau *pointeur
delete pointeur; //Ne pas oublier de libérer la mémoire
pointeur = 0; //Et de faire pointer le pointeur vers rien

55
return 0;
}
Ce programme est plus compliqué que sa version sans allocation dynamique ! C'est vrai. Mais
on a le contrôle complet sur l'allocation et la libération de la mémoire.
Dans la plupart des cas, ce n'est pas utile de le faire. Mais vous verrez plus tard que, pour faire
des fenêtres, la bibliothèque Qt utilise beaucoup new et delete. On peut ainsi maîtriser
précisément quand une fenêtre est ouverte et quand on la referme par exemple.

56
ANNEXE
Quelques fichiers d’entêtes du C++

Types de variables

57
Mots clés réservés de C++

58
Les fonctions mathématiques <math.h>
Fonctions trigonométriques et hyperboliques :

Fonctions exponentielles et logarithmiques :

Fonctions diverses :

59

Vous aimerez peut-être aussi