Algorithmique et python
Introduction, programmes et structures de base
Généralités sur les algorithmes
Algorithme
Un algorithme est une suite finie d'instructions
permettant la résolution systématique d'un problème donné.
Un algorithme peut-être utilisé pour
- décrire par une suite d'instructions ou de procédures la marche complète à suivre pour résoudre un problème;
- automatiser une tâche complexe; on sait déjà dans ce cas résoudre le problème posé et on cherche à tirer parti de moyens informatiques pour effectuer automatiquement toutes les étapes et tous les calculs intermédiaires qui permettent d'aboutir au résultat;
- chercher la solution d'un problème: on ne sait pas a priori résoudre le problème posé mais on peut tirer parti d'un système informatisé pour explorer l'ensemble des possibilités, et ainsi tenter de trouver la solution, ou du moins une bonne approximation de celle-ci.
Des exemples courants d'algorithmes sont donnés par les notices d'utilisation.
L'objectif dans ce cas est la description du problème à résoudre: le problème étant pour l'utilisateur d'utiliser correctement le produit concerné.
Si la notice est bien faite, c'est-à-dire, si l'algorithme donné est correcte, il ne doit y avoir aucune ambiguité lors de l'exécution des étapes successives, et, arrivé au bout de la notice, le produit visé doit être correctement utilisé.
Par exemple, voici la notice d'utilisation que l'on peut trouver au dos d'un bidon d'huile destinée à l'entretien de mobiliers en bois exotique (type teck):
- Vérifier que la surface est bien du teck ou un bois exotique
- Bien agiter avant emploi
- Imprégner le bois généreusement
- 20 minutes après, essuyer l'excédent à l'aide d'un chiffon
- Laisser sécher 6 heures
- Recommencer à partir de l'étape 2
- Laisser couler quelques gouttes d'eau sur la surface traitée
Si les gouttes perlent à la surface,
Alors le bois est correctement huilé et imperméabilisé
Sinon, recommencer à l'étape 2.
Cet algorithme est ici incorrect: à l'étape 6 on recommence à l'étape
2 systématiquement.
En particulier, en suivant celui-ci scrupuleusement, on n'arrive jamais à
l'étape 7, et donc on ne finit jamais cet algorithme.
La notice laisse ici apparemment le soin à l'utilisateur de juger par lui-même lorsqu'il a appliqué assez de produit.
Un algorithme correct doit éviter justement cela. Il ne doit pas laisser de place à l'interprétation du l'utilisateur, et doit être sans ambiguïté: l'utilisateur est un ordinateur qui n'interprète pas mais calcule.
L'algorithme précédent est écrit en français. Il aurait pu être écrit dans n'importe quelle langue vivante (on trouve d'ailleurs en général les notices écrites dans un certain nombre d'autres langues).
Si on veut faire exécuter un ensemble de tâches à un système automatisé (un ordinateur ou tout système electronique par exemple), une autre langue doit être utilisé. On parle alors de langage de programmation (d'une certaine façon la langue vivante comprise par le système automatisé), et de programme (la traduction de l'algorithme dans cette langue).
Langage de programmation & programme
Un langage de programmation est un ensemble d'instructions et
de règles syntaxiques compréhensibles par un système automatisé
(calculatrice, ordinateur, puce électronique,…).
Un programme est la traduction d'un algorithme dans un langage
de programmation particulier.
Il existe de très nombreux langages de programmation tels que, parmi bien d'autres, Basic, Fortran, Python, C, C++, Matlab, assembleur, ceux implantés dans les calculatrices (alors dites "programmables"…), javascript, php, …
Des ressources sont aussi disponibles pour Matlab, Scilab et python.
Variables
Variable
On appelle variable tout emplacement de la mémoire dans lequel une information peut-être stockée.
Une variable est constituée de :
Une variable est constituée de :
- un nom qui permet à l'ordinateur de la localiser dans sa mémoire
- une valeur: l'information qu'elle contient.
3→x
: on affecte (ou stocke) la valeur 3 dans la variable x
.
En Python, le symbole mathématique égal "
=
" est utilisé:
x=3
signifie qu'à partir de cette instruction la variable (nommée) x
a pour valeur 3.
Les variables sont les éléments les plus essentiels et fondamentaux de tout algorithme / programme.
Pour pouvoir maintenant effectuer des opérations sur ces variables, et surtout des opérations automatisées, il faut se munir de quelques structures:
- une structure conditionnelle, permettant d'indiquer que certains calculs ou certaines instructions ne sont à effectuer que sous certaines conditions
- des boucles, permettant d'effectuer automatiquement un certain nombre de calculs.
Instruction conditionnelle: "if…"
Le traitement d'une condition peut se représenter par l'algorithmeif test:
# instruction(s)
# si le test est vrai
Un exemple d'instruction conditionnelle est le suivant, en français:
Cette (simple) instruction conditionnelle est en fait ambigüe: imaginons que demain il pleuve, vais-je faire des maths ??
On peut en effet comprendre cette phrase de deux façons:
et les programmes en pseudo-python correspondants:
Demain, si il fait beau, alors je vais à la plage et je fais des maths.
Cette (simple) instruction conditionnelle est en fait ambigüe: imaginons que demain il pleuve, vais-je faire des maths ??
On peut en effet comprendre cette phrase de deux façons:
- Demain, si il fait beau, alors (je vais à la plage et je fais des maths).
- ou, en deux temps
(Demain, si il fait beau, alors je vais à la plage).
(Ensuite (qu'il fasse beau ou non), je fais des maths).
et les programmes en pseudo-python correspondants:
if beau:
plage
maths
if beau:
plage
maths
Plus généralement, on peut compléter la structure conditionnelle précédente en indiquant aussi quoi faire si la condition n'est pas vraie, sinon (else en anglais), voire même imbriquer plusieurs sinon. En python, on complète la structure précédente par un else (sinon):
if test:
# instruction(s)
# si le test est vrai
else:
# instruction(s)
# si le test est faux
Boucle itérative conditionnelle: "while…"
Le traitement d'une boucle conditionnelle, c'est-à-dire d'une boucle qui s'effectue sous certaines conditions, peut se représenter par l'algorithme En python, cette structure s'écrit:while test:
# instruction(s)
# si le test est vrai
Deux programmes complets et détaillés pour commencer
Par la suite, et avant de s'attaquer à plus d'éléments théoriques et généraux, deux programmes sont construits et détaillés pas à pas: Calcul d'aire et quadrature du cercle numérique et le jeu du nombre mystérieux. Le jeu du nombre mystérieux se joue à deux personnes de la manière suivante: un des deux joueurs choisit un nombre entier au hasard compris entre 1 et 100. Le but du deuxième joueur est de trouver ce nombre.Pour cela il propose un nombre au premier joueur qui lui fournit une des trois réponses:
- "Gagné", si le nombre proposé est le bon;
- "Trop grand", si le nombre proposé est plus grand que le nombre mystérieux;
- "Trop petit", si le nombre proposé est plus petit que le nombre mystérieux;
Essayer ! avant de le programmer !
Entrer un nombre:
Initiation / introduction à la programmation, en python: deux programmes construits et détaillés pas à pas: Jeu du nombre mystérieux