Cours 2018-2019

Algorithmique 2 [IHDCB331]

  • 10 crédits
  • 30h+30h
  • 1er quadrimestre
Langue d'enseignement: Français
Enseignant: Schobbens Pierre

Acquis d'apprentissage

L'étudiant sera capable de :

- formaliser un problème à partir d'un énoncé ;

- résoudre le problème de façon systématique pour proposer un programme correct et efficace.

Objectifs

Apprendre une démarche rigoureuse de construction de programmes efficaces: l'algorithmique.

Contenu

Toutes les méthodes reposent sur la démarche de spécification formelle, implémentation et preuve. L'évaluation de l'efficacité d'un problème est basée sur un calcul du temps d'éxécution et de consommation de la mémoire (théorie de la complexité) La récursion sert de base à ce cours.

Des méthodes systématiques de construction de programmes efficaces seront présentées: 1- la méthode "diviser pour régner" 2- les méthodes de mémorisation, dont la programmation dynamique 3- la méthodes gloutonne 4- la méthode générer/tester.

Pour mettre en oeuvre ces algorithme, on étudiera les structures de données récursives: arbres, arbres rouges-noirs, B-arbres, etc.

Table des matières

Partie 0. Spécification par pré et et post-conditions, preuves par invariants et variants. Evaluation du temps d'éxécution. Récursion. 

Partie I. Méthodes de construction de programmes. 1- la méthode "diviser pour régner" 2- les méthodes de mémorisation, dont la programmation dynamique 3- la méthodes gloutonne 4- la méthode générer/tester 

Partie II. Structures de données récursives:  listes, arbres, arbres rouges-noirs,etc.

 

Description des exercices

Les séances d'exercices sont organisées selon un triple perspective.

1- Consolidation des prérequis: - écriture de spécifications; - construction d'algorithmes par la technique de l'invariant; - types abstraits (liste chaînée, liste doublement chaînée, arbre binaire,...).

2- Appropriation des méthodes vues au cours théorique: - construction d'algorithmes par les différentes méthodes; - calcul de la complexité des algorithmes construits. 

Disciplines

Sémantique des langages de programmation
Programmation du calcul numérique

Pré-requis

Algorithmique 1 [IHDCB232]

Co-requis

Mathématiques pour l'informatique (2e partie) [IHDCB222]

Méthodes d'enseignement

Un cours magistral illustré de nombreux exemples, plus des travaux pratiques. Les étudiants sont également invités à faire des exercices à domicile.

Mode d'évaluation

1. Des interrogations en cours d'année comptent pour 10%.

2. Un mini-projet à remettre en fin d'année (dernier jour de cours) compte pour 20% 

3. L'examen écrit compte pour le reste (70%)

Sources, références et supports éventuels

Le cours suit une partie du livre: Introduction à l'algorithmique, de T. Cormen, C. Leiserson, R. Rivest, C. Stein (ed. Dunod).

Langue d'enseignement

Français

Lieu de l'activité

NAMUR

Faculté organisatrice

Faculté d'informatique
rue Grandgagnage 21
5000 NAMUR
T. 081725252
F. 081724967
secretariat.info@unamur.be

Cycle

Etudes de 1er cycle