Difference between revisions of "Courses/ALGO"

From LRDE

Line 8: Line 8:
 
|duration=28H
 
|duration=28H
 
|optional course=oui
 
|optional course=oui
  +
|module=Informatique Fondamentale
|objectives=Ce cours expose les notions de base de l'algorithmique, avec une emphase sur les calculs de complexité. Les présentation des algorithmes de tris et des structures de données classiques (pour la plupart déjà introduits en prépa) sert de support à l'introduction de la notion de complexité et des différents outils mathématiques qui permettent de l'étudier.
 
  +
|prerequisites=Programme Classes Préparatoires
 
|objectives=Ce cours expose les notions de base de l'algorithmique, avec une emphase sur les calculs de complexité. La présentation des algorithmes de tris et des structures de données classiques (pour la plupart déjà introduits en classes préparatoires intégrées) sert de support à l'introduction de la notion de complexité et des différents outils mathématiques qui permettent de l'étudier.
 
|content=* Introduction aux mesures de complexité (notations, théorème général, exemples du tri par insertion et du tri fusion)
 
|content=* Introduction aux mesures de complexité (notations, théorème général, exemples du tri par insertion et du tri fusion)
 
* Autres tri comparatifs (selection, tri par tas, tri rapide, tri introspectif)
 
* Autres tri comparatifs (selection, tri par tas, tri rapide, tri introspectif)
Line 15: Line 17:
 
* Rangs et médians (sélection stochastique, sélection en O(n))
 
* Rangs et médians (sélection stochastique, sélection en O(n))
 
* Structure de données classiques (tableaux statiques et dynamiques, listes, piles, files, files de priorité)
 
* Structure de données classiques (tableaux statiques et dynamiques, listes, piles, files, files de priorité)
* Structures associatives (tables de hachage, arbre binaires de recherche, arbre rouge et noir, skip lists)
+
* Structures associatives (tables de hachage, arbre binaires de recherche, arbre rouge et noir)
 
* Principaux paradigmes algorithmiques :
 
* Principaux paradigmes algorithmiques :
** diviser pour régner (ex.: tri fusion, Karatsuba)
+
a) diviser pour régner (ex.: tri fusion, Karatsuba)
** programmation dynamique (ex.: distance de Levenshtein, chaîne de multiplications de matrices, plus long sous-séquence commune)
+
b) programmation dynamique (ex.: distance de Levenshtein, chaîne de multiplications de matrices, plus longue sous-séquence commune)
** algorithmes gloutons (ex.: distributeur de monnaie, codage de Huffman)
+
c) algorithmes gloutons (ex.: distributeur de monnaie, codage de Huffman).
  +
|references=Book: "Introduction to algorithms" par Cormen, Leiserson, Rivest et Stein
+
|references="Introduction to algorithms" par Cormen, Leiserson, Rivest et Stein
 
[http://www.lrde.epita.fr/~adl/ens/algo/ Examens passés]
 
[http://www.lrde.epita.fr/~adl/ens/algo/ Examens passés]
 
|logbook=Courses/AlgoLog2010, Courses/AlgoLog2011Ing, Courses/AlgoLog2011App, Courses/AlgoLog2012Ing, Courses/AlgoLog2013Ing
 
|logbook=Courses/AlgoLog2010, Courses/AlgoLog2011Ing, Courses/AlgoLog2011App, Courses/AlgoLog2012Ing, Courses/AlgoLog2013Ing
 
 
|optional=non
 
|optional=non
 
}}
 
}}

Revision as of 12:14, 13 June 2014

Titre

Algorithmique

Sigle

ALGO

Enseignant

Alexandre Duret-Lutz

Période

Ing1

Public

Tronc-commun

Contrôle

Partiel, QCM

Durée

28H"H" is not declared as a valid unit of measurement for this property.

Optionnel

oui

Module

Informatique Fondamentale

Prérequis

Programme Classes Préparatoires

Objectifs

Ce cours expose les notions de base de l'algorithmique, avec une emphase sur les calculs de complexité. La présentation des algorithmes de tris et des structures de données classiques (pour la plupart déjà introduits en classes préparatoires intégrées) sert de support à l'introduction de la notion de complexité et des différents outils mathématiques qui permettent de l'étudier.

Plan
  • Introduction aux mesures de complexité (notations, théorème général, exemples du tri par insertion et du tri fusion)
  • Autres tri comparatifs (selection, tri par tas, tri rapide, tri introspectif)
  • Borne de complexité des tris comparatifs
  • Tris linéaires
  • Rangs et médians (sélection stochastique, sélection en O(n))
  • Structure de données classiques (tableaux statiques et dynamiques, listes, piles, files, files de priorité)
  • Structures associatives (tables de hachage, arbre binaires de recherche, arbre rouge et noir)
  • Principaux paradigmes algorithmiques :
 a) diviser pour régner (ex.: tri fusion, Karatsuba)
 b) programmation dynamique (ex.: distance de Levenshtein, chaîne de multiplications de matrices, plus longue sous-séquence commune)
 c) algorithmes gloutons (ex.: distributeur de monnaie, codage de Huffman).

Documentation
  • "Introduction to algorithms" par Cormen, Leiserson, Rivest et Stein
  • Examens passés
Support
Journaux