Pseudo-code I#
Excellent ! Je suis vraiment impressionné par ta motivation.
N'empêche, à continuer à ce rythme là, tu maîtriseras bientôt JavaScript ! ...et tu seras certainement en train de jouer (et gagner!) à CodinGame, débugguer du code les yeux fermés... ou développer tes propres applications !
Alors... on reprend ?
Il est actuellement 17h42 heure locale. La température extérieure est de 19°.
Le commandant de bord et son équipage sont heureux d'avoir voyagé avec toi sur Algorigrammes CodingLines. Nous te souhaitons un agréable séjour en Pseudo-code !
(Re-)présentation#
Dans le tout premier chapitre, je t'avais dit que le pseudo-code était une des nombreuses représentations possible d'un programme. Cette fois, avec le pseudo-code, on va exprimer nos programmes en langue quasi-naturelle, en français (mais c'est également possible en toutes les langues). Nous allons donc écrire des programmes sous forme de textes.
Cette représentation a l'avantage d'être proche du résultat final tout en étant indépendante des difficultés ou bugs liées à la mise en place réelle sur un ordinateur ! C'est plutôt bien pour décrire ses idées avant de les confronter à la réalité technique avec un autre langage.
Comme tu peux t'en douter, contrairement aux algorigrammes, il ne s'agit pas d'une représentation normalisée, mais juste d'une représentation pratique à griffonner sur un bout de feuille, à penser, ou éventuellement à dire à l'oral (il te restera à trouver le bon interlocuteur ^_^) ! Au final, il y a certainement autant de variantes du pseudo-code que de développeurs...
En pseudo-code nous chercherons encore à lever toutes les ambiguïtés et à préciser tous les concepts que l'on utilise, exactement comme dans les algorigrammes. Nous retrouverons aussi toutes les petites choses auxquelles nous nous sommes progressivement habituées lors des chapitres précédent : variables, instructions conditionnelles, boucles, fonctions... (et votre humble serviteur !)
Des algorigrammes au pseudo-code#
Attend un instant.. si le pseudo-code n'est qu'une représentation parmi d'autres... et si je te dis qu'on va faire comme dans les algorigrammes... Il y aurait donc des équivalences entre algorigrammes et pseudo-code ?
Hé oui ! Voyons ça ...
Instructions et structure du programme#
Comme avec les algorigrammes, un programme est constitué d'un début, d'une suites d'instructions et d'une fin. Ces instructions peuvent prendre deux formes : instructions simples et blocs contenant plusieurs instructions.
On lit les instructions dans l'ordre des lignes : pour les instructions simple c'est tout, mais pour les blocs d'instructions, il pourra y avoir des règles particulières pour savoir sur quelle ligne on continue à lire le programme.
Commentaires#
Les commentaires sont des lignes de texte qui n'ont pas de sens du point de vue du programme et qui ne doivent pas être prises en compte. C'est un peu comme des annotations qu'on aurait pu faire autour de nos algorigramme pour expliquer telle ou telle partie.
Nous allons utiliser pour cela le symbole //
. Tout ce qui sera à droite de ce symbole sera considéré comme un commentaire.
INSTRUCTION1 INSTRUCTION2 ... // Quatre lignes explicatives qui ne sont pas des instructions // et qu'il ne faut donc pas prendre en compte dans le code // mais qui peuvent être utiles pour comprendre ce qui // s'y passe ! INSTRUCTION31 INSTRUCTION32
Déclaration des variables#
En pseudo-code et de nombreux langages de programmation on prendra l'habitude de déclarer les variables tout au début du programme. Cela permet au programmeur de savoir qui est chaque variable, et de s'engager à ne l'utiliser que pour la description qui en est faite.
De plus, lorsqu'on utilisera des vrais langages informatiques, cela permettra de demander à l'ordinateur de préparer et donner des bouts de mémoire à notre programme : pour les étiquettes, pour les cases visées, etc.
PROGRAMME monprogramme(...) VARIABLE variable1 : description VARIABLE variable2 : description VARIABLE variable3 : description ... INSTRUCTION1 INSTRUCTION2 ... FINPROGRAMME
Assignation et lecture d'une variable#
L'utilisation des variables se fait exactement de la même manière en pseudo-code qu'en algorigrammes. La différence ? Pas besoin de mettre de rectangle autour !
Entrées & sorties#
Structure conditionnelle#
La structure conditionnelle est notre premier bloc d'instructions.
Autant dans les algorigrammes, on pouvait suivre les flèches pour choisir le "bon" coté du code à appliquer, autant en texte il va falloir ruser... puisqu'on ne peut écrire du code que de haut en bas !
L'astuce est simple :
- Si la valeur de
condition
est VRAI, alors on fait les lignes en rouges de la zone en haut (INSTRUCTION26 ...
), - Sinon c'est que
condition
est FAUX, on ignore la zone en haut pour passer directement aux lignes en rouges de la zone en bas (INSTRUCTION26bis ...
). - Quand on a fini les lignes en rouges de la zone choisie, on passe directement aux instructions en bleu qui suivent (
INSTRUCTION27 ...
)
Boucles#
Les boucles sont également représentées sous forme d'un bloc d'instructions. Là aussi il faut ruser pour distinguer ce qui est dans la boucle de ce qui est à coté.
Dans les chapitres précédents nous avions défini une boucle comme une zone de code répétée tant qu'une condition valait VRAI, mais nous n'avions pas précisé ou était la zone de code par rapport à notre condition ! Nous aurons donc deux façon de représenter les boucles, selon l'organisation de notre programme.
Boucles TANTQUE : où l'on teste la condition avant le premier tour#
Dans cette version de la boucle, on choisit de tester la valeur de condition
avant d'entrer dans la boucle.
- Si la valeur est VRAI, on passe aux instructions rouges
INSTRUCTION 26...
et suivantes. Quand c'est fait, on recommence à la ligneTANTQUE (condition) FAIRE
et on se repose la question de la condition. - Si la valeur est FAUX, on ignore les lignes en rouge et on passe directement aux instructions en bleu
INSTRUCTION27 ...
et suivantes.
Boucles FAIRE : où l'on teste la condition après un premier tour#
Dans cette autre version de la boucle, on rentre directement sur les instructions INSTRUCTIONS26...
. Lorsque c'est fait on tombe sur la condition :
Dans cette version de la boucle, on choisit de tester la valeur de condition
avant d'entrer dans la boucle.
- Si la valeur est VRAI, on remonte et on repasse par les instructions rouges
INSTRUCTION 26...
et suivantes, autant que nécessaire. - Si la valeur est FAUX, on passe directement aux instructions en bleu
INSTRUCTION27 ...
et suivantes.
Fonctions#
Les fonctions... sont aussi des blocs d'instructions !
On remarque que dans l'appel et dans définition d'une fonction, on note des paramètres à coté du nom, entre parenthèses. Par exemple : afficher(mon_texte)
.
Comment utiliser les paramètres ?#
Au niveau de la fonction appelante, ce sont les différentes valeurs que l'on souhaite transmettre à la fonction appelée. Cela peut être directement des valeurs textuelles, numériques, etc. (afficher("Hello world")
) ou bien des valeurs lues depuis des variables (afficher(salutations)
).
Au niveau de la fonction appelée, ces paramètres sont des variables que l'on a pas besoin de déclarer à l'intérieur de la fonction et qui seront initialisées à aux différentes valeurs que fournira l'appelant, au moment de l'appel et dans l'ordre des paramètres indiqués.
Par exemple si j'ai la fonction suivante (parfaitement valide) :
FONCTION salutation(prenom, age) afficher("Salut " + prenom + ", toi qui a " + age + "ans") FINFONCTION
- Lorsque j'appelerai
salutation("Anatole", 52)
, cela afficheraSalut Anatole, toi qui a 40 ans
- Lorsque j'appelerai
salutation("Philemon", 16)
, cela afficheraSalut Philemon, toi qui a 16 ans
- Lorsque j'appelerai
salutation("Vendredi", 40)
, cela afficheraSalut Vendredi, toi qui a 40 ans
- Et ainsi de suite... les variables
prenom
etage
changent de valeur à chaque appel, selon ce qui est passé en paramètres.
Comment utiliser la valeur de retour#
La valeur de retour est la valeur que l'on souhaite transmettre de la fonction appelée vers la fonction appelante. Elle est désignée par le mot clef RETOURNE
.
Dans l'illustration ci-dessus, on voit que cette valeur est lue depuis la variable calcul
du coté de fonction1
et qu'elle est transmise à la fonction appelante fonction2
. Du coté de la fonction appelante, la valeur reçue est alors stockée dans la variable resultat
. On ne s'intéresse qu'à la valeur et on perd toute trace du fait que cette valeur était associée à une autre variable dans le monde parallèle de la fonction fonction1
.
Autres détails#
Évidemment, l'exécution des instructions contenues dans une fonction appelée se fait uniquement au moment ou elle est mentionnée (avec ses paramètres) dans la fonction appelante.
D'ailleurs... lorsqu'on y réfléchit bien... un programme n'est rien de plus qu'une fonction qui serait la première à être appelé pour l'exécution ! Il appelle lui-même d'autres fonctions (qui en appellent éventuellement d'autres, etc.) !
— Et comment savez-vous que vous êtes fou ?
— Pour commencer, dit le Chat, est-ce que tu m’accordes qu’un chien n’est pas fou ?
— Sans doute.
— Eh bien, vois-tu, continua le Chat, tu remarqueras qu’un chien gronde lorsqu’il est en colère et remue la queue lorsqu’il est content. Or, moi je gronde quand je suis content, et je remue la queue quand je suis en colère. Donc, je suis fou.
Lewis Caroll, Alice au pays des merveilles
Conclusion#
Voilà, c'est fait ! Les bases sont posées. Nous avons tous les éléments nécessaires pour faire du vrai code !
Pour le prochain numéro, je te propose de ne pas trop nous attarder sur le pseudo-code et passer tout doucement vers JavaScript. Ce qui nous permettra en plus de voir notre code fonctionner !
Nous verrons aussi les solutions des exercices, évidemment.