Introduction à l Informatique (INF 311) Amphi 9 : stockage efficace de l information. Amphi 9: stockage efficace de l information

Dimension: px
Commencer à balayer dès la page:

Download "Introduction à l Informatique (INF 311) Amphi 9 : stockage efficace de l information. Amphi 9: stockage efficace de l information"

Transcription

1 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X2013 3/46 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X2013 4/46 Introduction à l Informatique (INF 311) Modéliser, Abstraire, Programmer F. Morain Amphi 9: stockage efficace de l information 16 juin 2014 Amphi 9 : stockage efficace de l information I. Quelques algorithmes de tri. II. Recherche dans un tableau. III. Hachage. IV. Utilisation des tables. A1: introduction A6 : réseaux et sécurité A2: tableaux A7 : listes chaînées A3: classes, objets A8 : arbres A4 : modularité A9 : stockage efficace de l information A5 : récursivité A10 : modélisations F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X2013 1/46 L affaire du banquier aveugle Un journaliste et un trader se font tuer. La bibliothèque du journaliste contient 1000 livres, celle du trader 100. Il existe au moins un livre physiquement identique dans les deux bibliothèques, qui est la clef d un cryptosystème (moyennement fort). Énigme: comment faire pour ne passer toute la nuit à ne pas trouver ce livre? F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X2013 2/46 I. Quelques algorithmes de tri Tri: ranger des informations dans un ordre donné; très utilisé dès qu on traite des résultats d expériences, etc.. Il existe beaucoup d algorithmes de tri, avec des propriétés très différentes suivant les contextes (tableaux, fichiers, disques, données binaires, etc.), différents modèles de coûts (comparaisons, affectations, mémoire, etc.). Abstraction: on peut se concentrer sur le tri d entiers. Thm. Tout algorithme utilisant des comparaisons pour trier n entiers demande au moins O(n log n) comparaisons.

2 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X2013 7/46 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X2013 8/46 A) Tri par sélection Le même algorithme en place Principe: on commence par chercher le plus petit élément t[i0] pour i0 dans [0..n[ et on le met dans u[0], puis le plus petit élément t[i1] pour i1 dans [0..n[\{i 0 qui est mis dans u[1], etc. t u Informatique durable: utiliser le minimum de mémoire auxiliaire. On peut parfois modifier les entrées (images, grands nombres, etc.). Au pire, on fait une copie avant. Principe: on cherche le plus petit élément t[i0] de t[0..n[ et on le permute avec t[0], puis le plus petit élément de t[1..n[ que l on permute avec t[1], etc. À la fin, le tableau t contient les éléments triés. t F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X2013 5/46 L interface Element F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X2013 6/46 Rappel graphique Dans le fichier Element.java: public interface Element{ public String tostring(); public boolean estpluspetit(element v); Une interface peut contenir: des méthodes d objets, des variables de classe final; mais ne peut pas contenir: des champs; des méthodes de classes. interface Element public class Tableau{ public static Element minimum(...) public class TestTableau public static void Test(Element[] t){ public class IntegerElt implements Element

3 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Utilisation dans Tableau.java public class Tableau{ public static void afficher(element[] t){ for(int i = 0; i < t.length; i++) TC.println(t[i]); // vive tostring()! public static Element minimum(element[] t){ int mini = 0; for(int i = 1; i < t.length; i++) if(t[i].estpluspetit(t[mini])) mini = i; return t[mini]; // utile pour la suite public static void echanger(element[] t, int i, int j){ Element tmp; tmp = t[i]; t[i] = t[j]; t[j] = tmp; Exemple 1 public class IntegerElt implements Element{ private int clef; // pas requis par l interface public IntegerElt(int n){ this.clef = n; // requis par l interface public String tostring(){ return "" + this.clef; // interface + compilation public boolean estpluspetit(element w){ return this.clef <= ((IntegerElt) w).clef; (dans IntegerElt.java). F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X2013 9/46 Exemple 1 (suite) F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Implantation import tc.tc; public class TestTableau{ public static void main(string[] args){ IntegerElt[] t = new IntegerElt[10]; for(int i = 0; i < t.length; i++) t[i] = new IntegerElt((int)(Math.random()*10)); Tableau.afficher(t); TC.println("min="+Tableau.minimum(t)); // et maintenant on trie Tableau.triSelection(t); Tableau.afficher(t); // trie les données contenues dans t public static void triselection(element[] t){ for(int i = 0; i < t.length; i++){ // le tableau t[0..i[ est déjà trié // on cherche indm tq // t[indm]=min(t[j], i <= j < t.length) int indm;... // on échange t[i] et t[indm] echanger(t, i, indm); (dans Tableau.java)

4 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Implantation (suite) Nombre d opérations du tri sélection public static void triselection(element[] t){ for(int i = 0; i < t.length; i++){ // le tableau t[0..i[ est déjà trié // on cherche indm tq // t[indm]=min(t[j], i <= j < t.length) int indm = i; for(int j = i+1; j < t.length; j++) if(t[j].estpluspetit(t[indm])) indm = j; // on échange t[i] et t[indm] echanger(t, i, indm); Rem. il suffit d utiliser i < t.length-1. À chaque itération: on compare t[i] à t[i+1], t[i+2],..., t[n-1], soit n 1 i comparaisons; on échange t[i] avec le minimum trouvé. On commence avec i = 0 et on finit avec i = n 2 : (n 1 0) + (n 1 1) + + (n 1 (n 2)) = (n 1) + (n 2) = n(n 1)/2 comparaisons, et n 1 échanges. Thm. Le tri par sélection nécessite donc de l ordre de n 2 comparaisons dans tous les cas (pire, moyen, meilleur). F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Comparaison et affectation F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 B) Tri par insertion Pour les entiers, c est à peu près le même coût. Il y a beaucoup de cas où une comparaison coûte plus cher qu une affectation, par exemple pour les String (coût = min des longueurs). De l utilité des références pour l affectation: String[] s = {"abcdef", "x"; String tmp = s[0]; s[0] = s[1]; s[1] = tmp; on comprend l utilité de manipuler des références... Principe : On suppose que t[0..i-1] est trié et on insère t[i] à sa place dans le tableau. t C est le cas pour les tableaux, les matrices, etc.

5 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Le programme public static void triinsertion(element[] t){ for(int i = 1; i < t.length; i++){ // t[0..i-1] est déjà trié Element tmp = t[i]; int j = i; // recherche la place de tmp dans t[0..i-1] while((j > 0) && tmp.estpluspetit(t[j-1])){ t[j] = t[j-1]; j = j-1; // ici, j = 0 ou bien tmp >= t[j-1] t[j] = tmp; Analyse du tri par insertion On trie π = (a 0,...,a n 1 ). Pour insérer a i dans (a 0,a 1,...,a i 1 ) triés, on effectue : c i = 1 + #{j < i,a j > a i comparaisons ; r i = 2 + c i recopies. Au total : C(π) = R(π) = 3(n 1) + Inv(π). n 1 n 1 c i = (n 1) + #{j < i,a j > a i ; i=1 i=1 {{ Inv(π) F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Inversions F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Calcul du nombre moyen d inversions Déf. (a i,a j ) est une inversion de la permutation π = (a 0,...,a n 1 ) ssi i < j et a i > a j. On note Inv(π) le nombre d inversions de π. Ex. La permutation π = (4,2,3,1,0) présente 9 inversions : Cas particuliers : (4,2),(4,3),(4,1),(4,0); (3,1),(3,0);(2,1),(2,0);(1,0). π = (0,1,...,n 1) : Inv(π) = 0 (et donc pas d échanges si le tableau est déjà trié) ; π = (n 1,n 2,...,0) : Inv(π) = n(n 1)/2. Pb: que vaut Inv(π) en moyenne? Inv n = π S n Inv(π) n! =?? Déf. L image miroir de π = (a 0,a 2,...,a n 1 ) est la permutation M(π) = (a n 1,a n 2,...,a 0 ). Prop. Inv(π) + Inv(M(π)) = n(n 1)/2. Dém. (a i,a j ) est une inversion pour π équivaut à (a j,a i ) n en est pas une pour M(π). Inv n = 1 2 π S n (Inv(π) + Inv(M(π))) n! = n(n 1) 4

6 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Conclusions sur les tris élémentaires Tri C(π) R(π) sélection n(n 1)/2 3(n 1) insertion (n 1) + Inv(π) 3(n 1) + Inv(π) Nombres de comparaisons : Tri min moy max sélection n(n 1)/2 n(n 1)/2 n(n 1)/2 insertion n 1 n(n + 3)/4 1 (n 2 1)/2 C) Un tri rapide: le tri fusion Diviser pour résoudre: on trie séparément la moitié gauche et la moitié droite, et on fusionne les deux moitiés Nombres de recopies : Tri min moy max sélection 3(n 1) 3(n 1) 3(n 1) insertion 3(n 1) (n 1)(n + 12)/4 (n 1)(n + 6)/2 Rem. les deux tris ont même complexité O(n 2 ), mais le tri par insertion dépend fortement de π. Si π = (0,1,...,n 1), le nombre de comparaisons est minimal. F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Implantation // Tri en place de t[g..d[ public static void trifusion(element[] t, int g, int d){ if((d-g) > 1){ int m = (g+d)/2; // on trie les deux moitiés trifusion(t, g, m);// lg <= (d-g)/2 trifusion(t, m, d);// ld <= (d-g)/2 interclasser(t, g, m, d); Appel par (surcharge) public static void trifusion(element[] t){ trifusion(t, 0, t.length); F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 La fusion Ex. On veut fusionner les tableaux : d Principe de l interclassement : on utilise deux têtes de lecture parcourant t[g..m[ et t[m..d[ et une tête d écriture remplissant le tableau auxiliaire tmp[g..d[. Coût : O(d g) comparaisons.

7 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 La fonction d interclassement public static void interclasser(element[] t, int g, int m, int d){ Element[] tmp = new Element[t.length]; int i = g; // tête gauche: g <= i < m int j = m; // tête droite: m <= j < d for(int k = g; k < d; k++){ if(i >= m)// moitié gauche finie tmp[k] = t[j++]; else if(j >= d)// moitié droite finie tmp[k] = t[i++]; else// on compare les deux têtes if(t[i].estpluspetit(t[j])) tmp[k] = t[i++]; else tmp[k] = t[j++]; for(int k = g; k < d; k++) t[k] = tmp[k]; // recopie finale F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 II. Recherche dans un tableau Pb. un élément donné se trouve-t-il dans un tableau? A) Recherche séquentielle Principe: on parcourt tout le tableau; si on trouve x dans le tableau, on retourne l indice correspondant, sinon -1. public static int indicedans(int[] t, int x){ for(int i = 0; i < t.length; i++) if(t[i] == x) return i; return -1; Prop. Le nombre de comparaisons est O(n) en moyenne sur tous les tableaux d entiers de taille n. Analyse du tri fusion T(n) = qui se résout en écrivant : 2T(n/2) {{ + {{ 2n appels récursifs recopies T(n) n = T(n/2) n/ Si n = 2 k, alors T(2 k ) = 2k2 k = O(nlogn). Ex. n = 2 20, le coût est Thm. Pour toute entrée de taille n, T(n) = O(nlogn). Rem. La place mémoire nécessaire est 2n au lieu de n. F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Avec l interface public interface Element{ public String tostring(); public boolean estpluspetit(element v); public boolean estegal(element v); Dans IntegerElt.java: public boolean estegal(element w){ return this.clef == ((IntegerElt) w).clef; Dans Tableau.java: public static int indicedans(element[] t, Element x){ for(int i = 0; i < t.length; i++) if(t[i].estegal(x)) return i; return -1;

8 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 B) Recherche dichotomique Peut-on faire mieux? non dans le modèle classique (O( n) dans le modèle quantique). oui si les données sont triées (à la création ou au moment des recherches). Principe: comme la recherche dans un dictionnaire. On ouvre à une page au milieu, puis on regarde si on doit chercher dans la moitié droite ou la moitié gauche. Version récursive // on recherche dans l intervalle [g, d[ // les éléments sont triés en ordre // croissant dans t public static int dichorec(element[] t, Element x, int g, int d){ if(g >= d) return -1; int m = (g+d)/2; if(t[m].estegal(x)) return m; else if(x.estpluspetit(t[m])) return dichorec(t, x, g, m); else return dichorec(t, x, m+1, d); // astuce F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Combien l algorithme fait-il de comparaisons? F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Analyse (suite) Appel de dichorec: On entre dans la fonction avec l intervalle [g,d[. Le cas intéressant est pour g < d. On effectue au plus deux comparaisons. On appelle récursivement la fonction sur l intervalle [g,d [ avec [g,d [= [g,m[ ou [m + 1,d[. Lemme fondamental. La longueur de l intervalle [g, d[ est d g. Lemme. d g d g 2 d g 2. Dém. m g = ((d + g)/2 g ) = ((d g)/2), d (m + 1) = (d (d + g)/2) 1 = ((d g)/2) 1. la longueur de l intervalle est divisée par 2 à chaque étape. Prop. La recherche dichomotique dans un tableau trié à n éléments nécessite dans le cas le pire log 2 n comparaisons. Dém. on fera au plus log 2 n appels, donc au plus log 2 n comparaisons. Ex. Pour n = 10 6, on passe de 500,000 comparaisons à 19. exercice. Modifier le programme pour renvoyer tous les indices i tels que t[i] = x.

9 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 C) Utilisation d un index Pb. Il y a N = 10 8 numéros de téléphones portables possibles : 06wwxxyyzz. On veut en stocker n N, triés par ordre croissant dans un tableau T[0..n[. On ne peut/veut pas utiliser un tableau de N éléments, mais on veut une recherche rapide dans T. Idée: découper [0,N[ en K = N/M intervalles de longueur M (un diviseur de N), I k = [km,(k + 1)M[, avec 0 k < K; on découpe T en K sous-tables: T k = I k T; ou encore T = T 0 T 1 T K 1 ; T k est stocké dans T[ind[k]..ind[k+1][, avec ind un tableau de taille K + 1 tel que ind[k] = n; quand on cherche X, on calcule k = X/M, puis on cherche X dans T k. Index Ex. T = [10, , , , ] avec n = 5, M = donne K = 4 et k I k ind 0 [0, [ 0 1 [ , [ 2 2 [ , [ 3 3 [ , [ T 0 = T[0,2[= {10, T 1 = T[2,3[= { T 2 = T[3,3[= /0 T 3 = T[3,5[= { , F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 La recherche proprement dite public static int rechercher(int[] t, int M, int[] index, int x){ int k = x / M; return dichorec(t, x, index[k], index[k+1]); public static void main(string[] args){ int[] T = new int[]{10, , , , ; int M = N/4; int[] index = creerindex(t, M); TC.println(rechercher(T, M, index, 20)); TC.println(rechercher(T, M, index, )); exercice. Programmer creerindex. F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Analyse Ce qu on a fait: on a partitionné T = T 0 T 1 T K 1 ; à x [0..N[, on a associé un entier h(x) tel que x T h(x). le coût de recherche est R(x) = temps de calcul de h(x) +O(log 2 #T h(x) ). Si les données sont bien équiréparties, on a R(x) = temps de calcul de h(x) + O(log 2 (n/k)). Ici: avec 0 x < N = KM, on calcule h(x) = x/m, 0 h(x) < K.

10 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Un indice pour tout le monde Principe: on associe à chaque objet un entier unique. On peut se servir de cet entier pour stocker l objet par exemple dans un tableau. Rem. Heureusement, sinon le compilateur aurait du mal. III. Hachage Algorithmique élémentaire, mon cher Watson! Comment calculer cet entier? Par exemple une chaîne de caractères peut être transformée en entier, puis l entier réduit si besoin. Ex: C(abcd) = = (((97 256) + 98) ) = Le banquier aveugle F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Faisons le point F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Exemple avec des entiers Ce qu on vient de voir: on peut stocker N éléments dans K tables de taille N/K, ce qui accélère la recherche, si on peut localiser facilement les tables auxiliaires. Hachage: on passe à la limite : K = N tables de taille 1 (i.e., un tableau de taille N). Pb. On veut ranger un ensemble Z d entiers strictement positifs dans une table de hachage T de taille T. Fonction de codage : h(z) = z mod T. Ex. Z = {11,59,32,44,301,26,199 ; T = 10 ; T est une table d ensembles. i T i 11, ,199 On doit utiliser des listes à cause des collisions! Les collisions sont inévitables, mais en nombre faible si h est bien choisie.

11 Algorithme Implantation Insertion : calculer h(z) ; faire T h(z) = T h(z) {z. Recherche : calculer h(z) ; retourner z T h(z)? Thm. Si α = N/T 1, alors #T i = O(1). Généralement: on travaille avec un tableau de taille fixe, typiquement un nombre premier p et on calcule h(s) = C(s) mod p. Ex: avec p = 10007, on trouve h(abcd) = Collision: h(bacn) = 5041, etc. mécanisme de gestion de collisions: utilisation de listes contenant les collisions avec la même adresse; hachage ouvert : on cherche le premier indice libre à partir de l adresse de départ (cf. poly). Rem. Marche très bien si le hachage est bon et garantit des additions/tests/suppressions en O(1). Cf. Knuth par exemple. F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 Retour à Ensemble public ReseauSocial(String n, int nmax){ this.nom = n; this.nb_membres = nmax; this.amis = new TableHachage[nmax]; for(int i = 0; i < nmax; i++) this.amis[i] = new TableHachage(); opération Tableau Chaine ABR hachage stockage n 2 n i A(i) n i A(i) n i A(i) contient O(A(i)) O(A(i)) O(log A(i)) O(1) ajouter O(1) O(1) O(log A(i)) O(1) enlever O(1) O(A(i)) O(log A(i)) O(1) afficher O(A(i)) O(A(i)) O(A(i)) O(#T(i)) A(i) = nombre d amis de i. F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 IV. Utilisation des tables Problème : comment stocker efficacement n objets de même type (un ensemble E)? ajouter supprimer rechercher tableau O(1) O(1) O(n) liste O(1), O(i) O(1), O(i) O(n) tableau trié O(n) O(n) O(log n) ABR O(log n) O(log n) O(log n) hachage O(1) O(1) O(1) Table petite: recherche séquentielle suffit (tableau statique ou liste dynamique). Table grande: ordre sur les données: tri + recherche dichotomique si statique ; ABR (équilibré) si dynamique. pas d ordre : hachage, ensemble dynamique. F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46

12 Et la mémoire? Derniers mots Pour des éléments de type T donné: tableau : n T + un int; ABR: n (T + deux références); hachage: n (petite liste de T). tableau hachage. tableau ABR. ABR?? hachage. exercice. Écrire une interface Table stockant des ElementS et les implantations associées. Résumé du cours : recherche d informations ; diviser pour résoudre; tables. Prochains rendez-vous : Groupes cet après-midi vendredi h30 15h h45 17h h30 15h h45 17h45 Jeudi 19 juin à 10h30: conf. scientifique d A. Canteaut. Prochain amphi: lundi 23 juin à 10h30. F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46 F. Morain École polytechnique Introduction à l Informatique (INF 311) Promo X /46

1 de 46. Algorithmique. Trouver et Trier. Florent Hivert. Mél : Florent.Hivert@lri.fr Page personnelle : http://www.lri.fr/ hivert

1 de 46. Algorithmique. Trouver et Trier. Florent Hivert. Mél : Florent.Hivert@lri.fr Page personnelle : http://www.lri.fr/ hivert 1 de 46 Algorithmique Trouver et Trier Florent Hivert Mél : Florent.Hivert@lri.fr Page personnelle : http://www.lri.fr/ hivert 2 de 46 Algorithmes et structures de données La plupart des bons algorithmes

Plus en détail

ARBRES BINAIRES DE RECHERCHE

ARBRES BINAIRES DE RECHERCHE ARBRES BINAIRES DE RECHERCHE Table de symboles Recherche : opération fondamentale données : éléments avec clés Type abstrait d une table de symboles (symbol table) ou dictionnaire Objets : ensembles d

Plus en détail

Architecture des Systèmes d Information Architecture des Systèmes d Information

Architecture des Systèmes d Information Architecture des Systèmes d Information Plan... Tableaux et tris I3 - Algorithmique et programmation 1 Rappels Nicol Delestre 2 Tableaux à n dimensions 3 Initiation aux tris Tableaux - v2.0.1 1 / 27 Tableaux - v2.0.1 2 / 27 Rappels : tableau

Plus en détail

Algorithmique, Structures de données et langage C

Algorithmique, Structures de données et langage C UNIVERSITE PAUL SABATIER TOULOUSE III Algorithmique, Structures de données et langage C L3 IUP AISEM/ICM Janvier 2005 J.M. ENJALBERT Chapitre 1 Rappels et compléments de C 1.1 Structures Une structure

Plus en détail

Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004. Loc Jeudi 29/4/2004

Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004. Loc Jeudi 29/4/2004 Questionnaire d'examen final INF1101 Sigle du cours Nom : Signature : Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004 Professeur(s)

Plus en détail

Définitions. Numéro à préciser. (Durée : )

Définitions. Numéro à préciser. (Durée : ) Numéro à préciser (Durée : ) On étudie dans ce problème l ordre lexicographique pour les mots sur un alphabet fini et plusieurs constructions des cycles de De Bruijn. Les trois parties sont largement indépendantes.

Plus en détail

introduction Chapitre 5 Récursivité Exemples mathématiques Fonction factorielle ø est un arbre (vide) Images récursives

introduction Chapitre 5 Récursivité Exemples mathématiques Fonction factorielle ø est un arbre (vide) Images récursives introduction Chapitre 5 Images récursives http ://univ-tln.fr/~papini/sources/flocon.htm Récursivité http://www.poulain.org/fractales/index.html Image qui se contient elle-même 1 Exemples mathématiques

Plus en détail

Exercices sur les interfaces

Exercices sur les interfaces Exercices sur les interfaces Fabrice Rossi 18 octobre 1999 1 Le type Object 1.1 Manipulations élémentaires Exercice 1.1 : Indiquer l affichage produit par le programme suivant : public class UpCast1 {

Plus en détail

1 Recherche en table par balayage

1 Recherche en table par balayage 1 Recherche en table par balayage 1.1 Problème de la recherche en table Une table désigne une liste ou un tableau d éléments. Le problème de la recherche en table est celui de la recherche d un élément

Plus en détail

Licence Bio Informatique Année 2004-2005. Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose...

Licence Bio Informatique Année 2004-2005. Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose... Université Paris 7 Programmation Objet Licence Bio Informatique Année 2004-2005 TD n 1 - Correction Premiers pas Exercice 1 Hello World parce qu il faut bien commencer par quelque chose... 1. Enregistrez

Plus en détail

Java Licence Professionnelle CISII, 2009-10

Java Licence Professionnelle CISII, 2009-10 Java Licence Professionnelle CISII, 2009-10 Cours 4 : Programmation structurée (c) http://www.loria.fr/~tabbone/cours.html 1 Principe - Les méthodes sont structurées en blocs par les structures de la programmation

Plus en détail

Algorithmique I. Augustin.Lux@imag.fr Roger.Mohr@imag.fr Maud.Marchal@imag.fr. Algorithmique I 20-09-06 p.1/??

Algorithmique I. Augustin.Lux@imag.fr Roger.Mohr@imag.fr Maud.Marchal@imag.fr. Algorithmique I 20-09-06 p.1/?? Algorithmique I Augustin.Lux@imag.fr Roger.Mohr@imag.fr Maud.Marchal@imag.fr Télécom 2006/07 Algorithmique I 20-09-06 p.1/?? Organisation en Algorithmique 2 séances par semaine pendant 8 semaines. Enseignement

Plus en détail

Chapitre 10. Les interfaces Comparable et Comparator 1

Chapitre 10. Les interfaces Comparable et Comparator 1 Chapitre 10: Les interfaces Comparable et Comparator 1/5 Chapitre 10 Les interfaces Comparable et Comparator 1 1 Ce chapitre a été extrait du document "Objets, Algorithmes, Patterns" de [René Lalement],

Plus en détail

Recherche dans un tableau

Recherche dans un tableau Chapitre 3 Recherche dans un tableau 3.1 Introduction 3.1.1 Tranche On appelle tranche de tableau, la donnée d'un tableau t et de deux indices a et b. On note cette tranche t.(a..b). Exemple 3.1 : 3 6

Plus en détail

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile Dans ce TP, vous apprendrez à définir le type abstrait Pile, à le programmer en Java à l aide d une interface

Plus en détail

Complexité. Licence Informatique - Semestre 2 - Algorithmique et Programmation

Complexité. Licence Informatique - Semestre 2 - Algorithmique et Programmation Complexité Objectifs des calculs de complexité : - pouvoir prévoir le temps d'exécution d'un algorithme - pouvoir comparer deux algorithmes réalisant le même traitement Exemples : - si on lance le calcul

Plus en détail

Suivant les langages de programmation, modules plus avancés : modules imbriqués modules paramétrés par des modules (foncteurs)

Suivant les langages de programmation, modules plus avancés : modules imbriqués modules paramétrés par des modules (foncteurs) Modularité Extensions Suivant les langages de programmation, modules plus avancés : modules imbriqués modules paramétrés par des modules (foncteurs) généricité modules de première classe : peuvent être

Plus en détail

Les arbres binaires de recherche

Les arbres binaires de recherche Institut Galilée Année 2010-2011 Algorithmique et arbres L2 TD 6 Les arbres binaires de recherche Type en C des arbres binaires (également utilisé pour les ABR) : typedef struct noeud_s { struct noeud_s

Plus en détail

Projet de programmation (IK3) : TP n 1 Correction

Projet de programmation (IK3) : TP n 1 Correction Projet de programmation (IK3) : TP n 1 Correction Semaine du 20 septembre 2010 1 Entrées/sorties, types de bases et structures de contrôle Tests et types de bases Tests et types de bases (entiers) public

Plus en détail

# let rec concat l1 l2 = match l1 with [] -> l2 x::l 1 -> x::(concat l 1 l2);; val concat : a list -> a list -> a list = <fun>

# let rec concat l1 l2 = match l1 with [] -> l2 x::l 1 -> x::(concat l 1 l2);; val concat : a list -> a list -> a list = <fun> 94 Programmation en OCaml 5.4.8. Concaténation de deux listes Définissons maintenant la fonction concat qui met bout à bout deux listes. Ainsi, si l1 et l2 sont deux listes quelconques, concat l1 l2 constitue

Plus en détail

Utilisation d objets : String et ArrayList

Utilisation d objets : String et ArrayList Chapitre 6 Utilisation d objets : String et ArrayList Dans ce chapitre, nous allons aborder l utilisation d objets de deux classes prédéfinies de Java d usage très courant. La première, nous l utilisons

Plus en détail

Généralités sur le Langage Java et éléments syntaxiques.

Généralités sur le Langage Java et éléments syntaxiques. Généralités sur le Langage Java et éléments syntaxiques. Généralités sur le Langage Java et éléments syntaxiques....1 Introduction...1 Genéralité sur le langage Java....1 Syntaxe de base du Langage...

Plus en détail

ALGORITHMIQUE II NOTION DE COMPLEXITE. SMI AlgoII

ALGORITHMIQUE II NOTION DE COMPLEXITE. SMI AlgoII ALGORITHMIQUE II NOTION DE COMPLEXITE 1 2 Comment choisir entre différents algorithmes pour résoudre un même problème? Plusieurs critères de choix : Exactitude Simplicité Efficacité (but de ce chapitre)

Plus en détail

Exercices types Algorithmique et simulation numérique Oral Mathématiques et algorithmique Banque PT

Exercices types Algorithmique et simulation numérique Oral Mathématiques et algorithmique Banque PT Exercices types Algorithmique et simulation numérique Oral Mathématiques et algorithmique Banque PT Ces exercices portent sur les items 2, 3 et 5 du programme d informatique des classes préparatoires,

Plus en détail

Cours d initiation à la programmation en C++ Johann Cuenin

Cours d initiation à la programmation en C++ Johann Cuenin Cours d initiation à la programmation en C++ Johann Cuenin 11 octobre 2014 2 Table des matières 1 Introduction 5 2 Bases de la programmation en C++ 7 3 Les types composés 9 3.1 Les tableaux.............................

Plus en détail

Tp 1 correction. Structures de données (IF2)

Tp 1 correction. Structures de données (IF2) Tp 1 correction Structures de données (IF2) Remarque générale : compilez et exécutez le code au-fur-et-à mesure de son écriture. Il est plus facile de corriger une petite portion de code délimitée que

Plus en détail

Premiers Pas en Programmation Objet : les Classes et les Objets

Premiers Pas en Programmation Objet : les Classes et les Objets Chapitre 2 Premiers Pas en Programmation Objet : les Classes et les Objets Dans la première partie de ce cours, nous avons appris à manipuler des objets de type simple : entiers, doubles, caractères, booléens.

Plus en détail

Quelques Algorithmes simples

Quelques Algorithmes simples Quelques Algorithmes simples Irène Guessarian ig@liafa.jussieu.fr 10 janvier 2012 Je remercie Patrick Cegielski de son aide efficace pour la programmation Java ; la section sur le codage de Huffman a été

Plus en détail

Chapitre VI- La validation de la composition.

Chapitre VI- La validation de la composition. Chapitre VI- La validation de la composition. Objectifs du chapitre : Expliquer les conséquences de l utilisation de règles de typage souples dans SEP. Présenter le mécanisme de validation des connexions

Plus en détail

Objets et Programmation. origine des langages orientés-objet

Objets et Programmation. origine des langages orientés-objet Objets et Programmation origine des langages orientés-objet modularité, encapsulation objets, classes, messages exemples en Java héritage, liaison dynamique G. Falquet, Th. Estier CUI Université de Genève

Plus en détail

Polymorphisme, la classe Object, les package et la visibilité en Java... 1

Polymorphisme, la classe Object, les package et la visibilité en Java... 1 Polymorphisme, la classe Object, les package et la visibilité en Java. Polymorphisme, la classe Object, les package et la visibilité en Java.... 1 Polymorphisme.... 1 Le DownCast... 4 La Classe Object....

Plus en détail

Capacité d un canal Second Théorème de Shannon. Théorie de l information 1/34

Capacité d un canal Second Théorème de Shannon. Théorie de l information 1/34 Capacité d un canal Second Théorème de Shannon Théorie de l information 1/34 Plan du cours 1. Canaux discrets sans mémoire, exemples ; 2. Capacité ; 3. Canaux symétriques ; 4. Codage de canal ; 5. Second

Plus en détail

4. Les structures de données statiques

4. Les structures de données statiques 4. Les structures de données statiques 4.1 Tableaux à une dimension 4.1.1 Introduction Imaginons que dans un programme, nous ayons besoin simultanément de 25 valeurs (par exemple, des notes pour calculer

Plus en détail

Corrigés des premiers exercices sur les classes

Corrigés des premiers exercices sur les classes Corrigés des premiers exercices sur les classes Exercice 2.1.1 utilisation d une classe Voici le texte d une classe représentant de façon sommaire un compte bancaire et les opérations bancaires courantes.

Plus en détail

Corrigé des exercices sur les références

Corrigé des exercices sur les références Corrigé des exercices sur les références Exercice 3.1.1 dessin Pour cet exercice, vous allez dessiner des structures de données au moyen de petits schémas analogues à ceux du cours, comportant la pile

Plus en détail

Package Java.util Classe générique

Package Java.util Classe générique Package Java.util Classe générique 1 Classe Vector La taille est dynamique: dès qu un tableau vectoriel est plein, sa taille est doublée, triplée, etc. automatiquement Les cases sont de type Object add(object

Plus en détail

LMI 2. Programmation Orientée Objet POO - Cours 9. Said Jabbour. jabbour@cril.univ-artois.fr www.cril.univ-artois.fr/~jabbour

LMI 2. Programmation Orientée Objet POO - Cours 9. Said Jabbour. jabbour@cril.univ-artois.fr www.cril.univ-artois.fr/~jabbour LMI 2 Programmation Orientée Objet POO - Cours 9 Said Jabbour jabbour@cril.univ-artois.fr www.cril.univ-artois.fr/~jabbour CRIL UMR CNRS 8188 Faculté des Sciences - Univ. Artois Février 2011 Les collections

Plus en détail

RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION)

RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION) CLASSE RACINE Object ancêtre de toutes les classes RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION) définit donc des méthodes héritées par toutes

Plus en détail

TD/TP PAC - Programmation n 3

TD/TP PAC - Programmation n 3 Université Paris Sud Licence d informatique/iup-miage2 Année 2004-2005 Auteur : Frédéric Vernier Semaine : 11-16 octobre 2004 Conditions : sur machine avec les outils standards java web: http://vernier.frederic.free.fr/indexpac.html

Plus en détail

Les structures de données. Rajae El Ouazzani

Les structures de données. Rajae El Ouazzani Les structures de données Rajae El Ouazzani Les arbres 2 1- Définition de l arborescence Une arborescence est une collection de nœuds reliés entre eux par des arcs. La collection peut être vide, cad l

Plus en détail

PROJET ALGORITHMIQUE ET PROGRAMMATION II

PROJET ALGORITHMIQUE ET PROGRAMMATION II PROJET 1 ALGORITHMIQUE ET PROGRAMMATION II CONTENU DU RAPPORT A RENDRE : o Fiche signalétique du binôme o Listing des différents fichiers sources o CD sources o Il sera tenu compte de la présentation du

Plus en détail

Bases de programmation. Cours 5. Structurer les données

Bases de programmation. Cours 5. Structurer les données Bases de programmation. Cours 5. Structurer les données Pierre Boudes 1 er décembre 2014 This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 3.0 License. Types char et

Plus en détail

Représentation d un entier en base b

Représentation d un entier en base b Représentation d un entier en base b 13 octobre 2012 1 Prérequis Les bases de la programmation en langage sont supposées avoir été travaillées L écriture en base b d un entier est ainsi défini à partir

Plus en détail

Licence Sciences et Technologies Examen janvier 2010

Licence Sciences et Technologies Examen janvier 2010 Université de Provence Introduction à l Informatique Licence Sciences et Technologies Examen janvier 2010 Année 2009-10 Aucun document n est autorisé Les exercices peuvent être traités dans le désordre.

Plus en détail

1/24. I passer d un problème exprimé en français à la réalisation d un. I expressions arithmétiques. I structures de contrôle (tests, boucles)

1/24. I passer d un problème exprimé en français à la réalisation d un. I expressions arithmétiques. I structures de contrôle (tests, boucles) 1/4 Objectif de ce cours /4 Objectifs de ce cours Introduction au langage C - Cours Girardot/Roelens Septembre 013 Du problème au programme I passer d un problème exprimé en français à la réalisation d

Plus en détail

INITIATION AU LANGAGE C SUR PIC DE MICROSHIP

INITIATION AU LANGAGE C SUR PIC DE MICROSHIP COURS PROGRAMMATION INITIATION AU LANGAGE C SUR MICROCONTROLEUR PIC page 1 / 7 INITIATION AU LANGAGE C SUR PIC DE MICROSHIP I. Historique du langage C 1972 : naissance du C dans les laboratoires BELL par

Plus en détail

Exceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ;

Exceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ; CNAM NFP121 TP 10 19/11/2013 (Séance 5) Objectif Manipuler les exceptions ; 1 Entrées/sorties Exercice 1 : Lire un entier à partir du clavier Ajouter une méthode readint(string message) dans la classe

Plus en détail

Structure d un programme et Compilation Notions de classe et d objet Syntaxe

Structure d un programme et Compilation Notions de classe et d objet Syntaxe Cours1 Structure d un programme et Compilation Notions de classe et d objet Syntaxe POO 1 Programmation Orientée Objet Un ensemble d objet qui communiquent Pourquoi POO Conception abstraction sur les types

Plus en détail

TD3: tableaux avancées, première classe et chaînes

TD3: tableaux avancées, première classe et chaînes TD3: tableaux avancées, première classe et chaînes de caractères 1 Lestableaux 1.1 Élémentsthéoriques Déclaration des tableaux Pour la déclaration des tableaux, deux notations sont possibles. La première

Plus en détail

Plan du cours. Historique du langage http://www.oracle.com/technetwork/java/index.html. Nouveautés de Java 7

Plan du cours. Historique du langage http://www.oracle.com/technetwork/java/index.html. Nouveautés de Java 7 Université Lumière Lyon 2 Faculté de Sciences Economiques et Gestion KHARKIV National University of Economic Introduction au Langage Java Master Informatique 1 ère année Julien Velcin http://mediamining.univ-lyon2.fr/velcin

Plus en détail

Cours d introduction à l informatique. Partie 2 : Comment écrire un algorithme? Qu est-ce qu une variable? Expressions et instructions

Cours d introduction à l informatique. Partie 2 : Comment écrire un algorithme? Qu est-ce qu une variable? Expressions et instructions Cours d introduction à l informatique Partie 2 : Comment écrire un algorithme? Qu est-ce qu une variable? Expressions et instructions Qu est-ce qu un Une recette de cuisine algorithme? Protocole expérimental

Plus en détail

Encapsulation. L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets.

Encapsulation. L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets. Encapsulation L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets. La visibilité dépend des membres : certains membres peuvent être visibles et d'autres

Plus en détail

Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère

Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère L'héritage et le polymorphisme en Java Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère En java, toutes les classes sont dérivée de la

Plus en détail

Projet d informatique M1BI : Compression et décompression de texte. 1 Généralités sur la compression/décompression de texte

Projet d informatique M1BI : Compression et décompression de texte. 1 Généralités sur la compression/décompression de texte Projet d informatique M1BI : Compression et décompression de texte Le but de ce projet est de coder un programme réalisant de la compression et décompression de texte. On se proposera de coder deux algorithmes

Plus en détail

Grandes lignes ASTRÉE. Logiciels critiques. Outils de certification classiques. Inspection manuelle. Definition. Test

Grandes lignes ASTRÉE. Logiciels critiques. Outils de certification classiques. Inspection manuelle. Definition. Test Grandes lignes Analyseur Statique de logiciels Temps RÉel Embarqués École Polytechnique École Normale Supérieure Mercredi 18 juillet 2005 1 Présentation d 2 Cadre théorique de l interprétation abstraite

Plus en détail

Les bases de l informatique et de la programmation. École polytechnique

Les bases de l informatique et de la programmation. École polytechnique Les bases de l informatique et de la programmation École polytechnique François Morain 2 2 Table des matières I Introduction à la programmation 11 1 Les premiers pas en Java 13 1.1 Le premier programme............................

Plus en détail

Java Licence Professionnelle 2009-2010. Cours 7 : Classes et méthodes abstraites

Java Licence Professionnelle 2009-2010. Cours 7 : Classes et méthodes abstraites Java Licence Professionnelle 2009-2010 Cours 7 : Classes et méthodes abstraites 1 Java Classes et méthodes abstraites - Le mécanisme des classes abstraites permet de définir des comportements (méthodes)

Plus en détail

Cours 1: Java et les objets

Cours 1: Java et les objets Ressources Les interface homme-machine et le langage Java DUT première année Henri Garreta, Faculté des Sciences (Luminy) Cyril Pain-Barre & Sébastien Nedjar, IUT d Aix-Marseille (Aix) Cours 1: infodoc.iut.univ-aix.fr/~ihm/

Plus en détail

TD/TP PAC - Programmation n 3

TD/TP PAC - Programmation n 3 Université Paris Sud Licence d informatique/iup-miage2 - Année 2004-2005 auteur : Frédéric Vernier semaine : 11-16 octobre 2004 conditions : sur machine avec les outils standards java web: http://vernier.frederic.free.fr/indexpac.html

Plus en détail

TP, première séquence d exercices.

TP, première séquence d exercices. TP, première séquence d exercices. Benoît Valiron benoit.valiron@lipn.univ-paris13.fr 7 novembre 2010 Introduction Vous écrirez les réponses aux questions courtes sur une feuille à rendre à la fin de la

Plus en détail

Initiation à l algorithmique

Initiation à l algorithmique Informatique S1 Initiation à l algorithmique procédures et fonctions 2. Appel d une fonction Jacques TISSEAU Ecole Nationale d Ingénieurs de Brest Technopôle Brest-Iroise CS 73862-29238 Brest cedex 3 -

Plus en détail

Programmer en JAVA. par Tama (tama@via.ecp.fr( tama@via.ecp.fr)

Programmer en JAVA. par Tama (tama@via.ecp.fr( tama@via.ecp.fr) Programmer en JAVA par Tama (tama@via.ecp.fr( tama@via.ecp.fr) Plan 1. Présentation de Java 2. Les bases du langage 3. Concepts avancés 4. Documentation 5. Index des mots-clés 6. Les erreurs fréquentes

Plus en détail

Initiation à la programmation en Python

Initiation à la programmation en Python I-Conventions Initiation à la programmation en Python Nom : Prénom : Une commande Python sera écrite en caractère gras. Exemples : print 'Bonjour' max=input("nombre maximum autorisé :") Le résultat de

Plus en détail

Algorithmique et Programmation, IMA

Algorithmique et Programmation, IMA Algorithmique et Programmation, IMA Cours 2 : C Premier Niveau / Algorithmique Université Lille 1 - Polytech Lille Notations, identificateurs Variables et Types de base Expressions Constantes Instructions

Plus en détail

Cours de C++ François Laroussinie. 2 novembre 2005. Dept. d Informatique, ENS de Cachan

Cours de C++ François Laroussinie. 2 novembre 2005. Dept. d Informatique, ENS de Cachan Cours de C++ François Laroussinie Dept. d Informatique, ENS de Cachan 2 novembre 2005 Première partie I Introduction Introduction Introduction Algorithme et programmation Algorithme: méthode pour résoudre

Plus en détail

Auto-évaluation Programmation en Java

Auto-évaluation Programmation en Java Auto-évaluation Programmation en Java Document: f0883test.fm 22/01/2013 ABIS Training & Consulting P.O. Box 220 B-3000 Leuven Belgium TRAINING & CONSULTING INTRODUCTION AUTO-ÉVALUATION PROGRAMMATION EN

Plus en détail

Travaux pratiques. Compression en codage de Huffman. 1.3. Organisation d un projet de programmation

Travaux pratiques. Compression en codage de Huffman. 1.3. Organisation d un projet de programmation Université de Savoie Module ETRS711 Travaux pratiques Compression en codage de Huffman 1. Organisation du projet 1.1. Objectifs Le but de ce projet est d'écrire un programme permettant de compresser des

Plus en détail

Souad EL Bernoussi. Groupe d Analyse Numérique et Optimisation Rabat http ://www.fsr.ac.ma/ano/

Souad EL Bernoussi. Groupe d Analyse Numérique et Optimisation Rabat http ://www.fsr.ac.ma/ano/ Recherche opérationnelle Les démonstrations et les exemples seront traités en cours Souad EL Bernoussi Groupe d Analyse Numérique et Optimisation Rabat http ://www.fsr.ac.ma/ano/ Table des matières 1 Programmation

Plus en détail

Quelques algorithmes simples dont l analyse n est pas si simple

Quelques algorithmes simples dont l analyse n est pas si simple Quelques algorithmes simples dont l analyse n est pas si simple Michel Habib habib@liafa.jussieu.fr http://www.liafa.jussieu.fr/~habib Algorithmique Avancée M1 Bioinformatique, Octobre 2008 Plan Histoire

Plus en détail

Programmation Par Objets

Programmation Par Objets Programmation Par Objets Structures de données package java.util B. Carré Polytech Lille 1 Tableaux et structures de données Tableaux «Objets» taille fixe type des éléments : primitif (homogène) ou objets

Plus en détail

Machines virtuelles Cours 1 : Introduction

Machines virtuelles Cours 1 : Introduction Machines virtuelles Cours 1 : Introduction Pierre Letouzey 1 pierre.letouzey@inria.fr PPS - Université Denis Diderot Paris 7 janvier 2012 1. Merci à Y. Régis-Gianas pour les transparents Qu est-ce qu une

Plus en détail

Cours 1 : Qu est-ce que la programmation?

Cours 1 : Qu est-ce que la programmation? 1/65 Introduction à la programmation Cours 1 : Qu est-ce que la programmation? Yann Régis-Gianas yrg@pps.univ-paris-diderot.fr Université Paris Diderot Paris 7 2/65 1. Sortez un appareil qui peut se rendre

Plus en détail

Programmation par les Objets en Java

Programmation par les Objets en Java Programmation par les Objets en Java Najib TOUNSI Les classes en Java (TD 3) I. Notion de classe I.1 Classe, champs, méthodes, instanciation, this, private vs. public. Créer une classe Point (coordonnée

Plus en détail

Chaînes de Markov au lycée

Chaînes de Markov au lycée Journées APMEP Metz Atelier P1-32 du dimanche 28 octobre 2012 Louis-Marie BONNEVAL Chaînes de Markov au lycée Andreï Markov (1856-1922) , série S Problème 1 Bonus et malus en assurance automobile Un contrat

Plus en détail

TP3 : Manipulation et implantation de systèmes de fichiers 1

TP3 : Manipulation et implantation de systèmes de fichiers 1 École Normale Supérieure Systèmes et réseaux Année 2012-2013 TP3 : Manipulation et implantation de systèmes de fichiers 1 1 Répertoire de travail courant Le but de l exercice est d écrire une commande

Plus en détail

INF 232: Langages et Automates. Travaux Dirigés. Université Joseph Fourier, Université Grenoble 1 Licence Sciences et Technologies

INF 232: Langages et Automates. Travaux Dirigés. Université Joseph Fourier, Université Grenoble 1 Licence Sciences et Technologies INF 232: Langages et Automates Travaux Dirigés Université Joseph Fourier, Université Grenoble 1 Licence Sciences et Technologies Année Académique 2013-2014 Année Académique 2013-2014 UNIVERSITÉ JOSEPH

Plus en détail

Licence ST Université Claude Bernard Lyon I LIF1 : Algorithmique et Programmation C Bases du langage C 1 Conclusion de la dernière fois Introduction de l algorithmique générale pour permettre de traiter

Plus en détail

ÉPREUVE COMMUNE DE TIPE 2008 - Partie D

ÉPREUVE COMMUNE DE TIPE 2008 - Partie D ÉPREUVE COMMUNE DE TIPE 2008 - Partie D TITRE : Les Fonctions de Hachage Temps de préparation :.. 2 h 15 minutes Temps de présentation devant le jury :.10 minutes Entretien avec le jury :..10 minutes GUIDE

Plus en détail

Programmation C. Apprendre à développer des programmes simples dans le langage C

Programmation C. Apprendre à développer des programmes simples dans le langage C Programmation C Apprendre à développer des programmes simples dans le langage C Notes de cours sont disponibles sur http://astro.u-strasbg.fr/scyon/stusm (attention les majuscules sont importantes) Modalités

Plus en détail

Bases de données documentaires et distribuées Cours NFE04

Bases de données documentaires et distribuées Cours NFE04 Bases de données documentaires et distribuées Cours NFE04 Introduction a la recherche d information Auteurs : Raphaël Fournier-S niehotta, Philippe Rigaux, Nicolas Travers prénom.nom@cnam.fr Département

Plus en détail

V- Manipulations de nombres en binaire

V- Manipulations de nombres en binaire 1 V- Manipulations de nombres en binaire L ordinateur est constitué de milliards de transistors qui travaillent comme des interrupteurs électriques, soit ouverts soit fermés. Soit la ligne est activée,

Plus en détail

as Architecture des Systèmes d Information

as Architecture des Systèmes d Information Plan Plan Programmation - Introduction - Nicolas Malandain March 14, 2005 Introduction à Java 1 Introduction Présentation Caractéristiques Le langage Java 2 Types et Variables Types simples Types complexes

Plus en détail

Programmation Objet I

Programmation Objet I 2002-2003 UFR Mathématique de la Décision Deuxième Année de DEUG Science mention MASS Programmation Objet I Fabrice Rossi et Fabien Napolitano c Fabrice Rossi et Fabien Napolitano, 2002-2003 Le code de

Plus en détail

IN 102 - Cours 1. 1 Informatique, calculateurs. 2 Un premier programme en C

IN 102 - Cours 1. 1 Informatique, calculateurs. 2 Un premier programme en C IN 102 - Cours 1 Qu on le veuille ou non, les systèmes informatisés sont désormais omniprésents. Même si ne vous destinez pas à l informatique, vous avez de très grandes chances d y être confrontés en

Plus en détail

de calibration Master 2: Calibration de modèles: présentation et simulation d

de calibration Master 2: Calibration de modèles: présentation et simulation d Master 2: Calibration de modèles: présentation et simulation de quelques problèmes de calibration Plan de la présentation 1. Présentation de quelques modèles à calibrer 1a. Reconstruction d une courbe

Plus en détail

UEO11 COURS/TD 1. nombres entiers et réels codés en mémoire centrale. Caractères alphabétiques et caractères spéciaux.

UEO11 COURS/TD 1. nombres entiers et réels codés en mémoire centrale. Caractères alphabétiques et caractères spéciaux. UEO11 COURS/TD 1 Contenu du semestre Cours et TDs sont intégrés L objectif de ce cours équivalent a 6h de cours, 10h de TD et 8h de TP est le suivant : - initiation à l algorithmique - notions de bases

Plus en détail

Lambda! Rémi Forax Univ Paris-Est Marne-la-Vallée

Lambda! Rémi Forax Univ Paris-Est Marne-la-Vallée Lambda! Rémi Forax Univ Paris-Est Marne-la-Vallée forax at univ-mlv dot fr - ParisJUG Java.next() - Mars 2012 What Else? Lambda == Inner class? Java a des lambdas depuis la version 1.1 Exemple utilisant

Plus en détail

Chapitre 7. Récurrences

Chapitre 7. Récurrences Chapitre 7 Récurrences 333 Plan 1. Introduction 2. Applications 3. Classification des récurrences 4. Résolution de récurrences 5. Résumé et comparaisons Lectures conseillées : I MCS, chapitre 20. I Rosen,

Plus en détail

Arithmétique binaire. Chapitre. 5.1 Notions. 5.1.1 Bit. 5.1.2 Mot

Arithmétique binaire. Chapitre. 5.1 Notions. 5.1.1 Bit. 5.1.2 Mot Chapitre 5 Arithmétique binaire L es codes sont manipulés au quotidien sans qu on s en rende compte, et leur compréhension est quasi instinctive. Le seul fait de lire fait appel au codage alphabétique,

Plus en détail

6. Hachage. Accès aux données d'une table avec un temps constant Utilisation d'une fonction pour le calcul d'adresses

6. Hachage. Accès aux données d'une table avec un temps constant Utilisation d'une fonction pour le calcul d'adresses 6. Hachage Accès aux données d'une table avec un temps constant Utilisation d'une fonction pour le calcul d'adresses PLAN Définition Fonctions de Hachage Méthodes de résolution de collisions Estimation

Plus en détail

Solutions du chapitre 4

Solutions du chapitre 4 Solutions du chapitre 4 Structures de contrôle: première partie 4.9 Identifiez et corrigez les erreurs (il peut y en avoir plus d une par segment de code) de chacune des proposition suivantes: a) if (

Plus en détail

Université du Québec à Chicoutimi. Département d informatique et de mathématique. Plan de cours. Titre : Élément de programmation.

Université du Québec à Chicoutimi. Département d informatique et de mathématique. Plan de cours. Titre : Élément de programmation. Université du Québec à Chicoutimi Département d informatique et de mathématique Plan de cours Titre : Élément de programmation Sigle : 8inf 119 Session : Automne 2001 Professeur : Patrice Guérin Local

Plus en détail

Feuille TD n 1 Exercices d algorithmique éléments de correction

Feuille TD n 1 Exercices d algorithmique éléments de correction Master Sciences, Technologies, Santé Mention Mathématiques, spécialité Enseignement des mathématiques Algorithmique et graphes, thèmes du second degré Feuille TD n 1 Exercices d algorithmique éléments

Plus en détail

Conventions d écriture et outils de mise au point

Conventions d écriture et outils de mise au point Logiciel de base Première année par alternance Responsable : Christophe Rippert Christophe.Rippert@Grenoble-INP.fr Introduction Conventions d écriture et outils de mise au point On va utiliser dans cette

Plus en détail

Cours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre 2009. Enrica.Duchi@liafa.jussieu.fr

Cours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre 2009. Enrica.Duchi@liafa.jussieu.fr . Cours intensif Java 1er cours: de C à Java Septembre 2009 Enrica DUCHI LIAFA, Paris 7 Enrica.Duchi@liafa.jussieu.fr LANGAGES DE PROGRAMMATION Pour exécuter un algorithme sur un ordinateur il faut le

Plus en détail

Utiliser Java sans BlueJ

Utiliser Java sans BlueJ Conception objet en Java avec BlueJ une approche interactive Utiliser Java sans BlueJ Michael Kölling version française: Patrice Moreaux Rédigé avec 1.0 Conception objet en Java avec BlueJ une approche

Plus en détail

Représentation des Nombres

Représentation des Nombres Chapitre 5 Représentation des Nombres 5. Representation des entiers 5.. Principe des représentations en base b Base L entier écrit 344 correspond a 3 mille + 4 cent + dix + 4. Plus généralement a n a n...

Plus en détail

INTRODUCTION A JAVA. Fichier en langage machine Exécutable

INTRODUCTION A JAVA. Fichier en langage machine Exécutable INTRODUCTION A JAVA JAVA est un langage orienté-objet pur. Il ressemble beaucoup à C++ au niveau de la syntaxe. En revanche, ces deux langages sont très différents dans leur structure (organisation du

Plus en détail

Page 1 sur 5 TP3. Thèmes du TP : l la classe Object. l Vector<T> l tutorial Interfaces. l Stack<T>

Page 1 sur 5 TP3. Thèmes du TP : l la classe Object. l Vector<T> l tutorial Interfaces. l Stack<T> Page 1 sur 5 TP3 Lectures préalables : l Java_II l tutorial Interfaces Thèmes du TP : l la classe Object l Vector l Stack Une pile d'objects Les éléments de la classe Pile sont maintenant des instances

Plus en détail

Initiation. àl algorithmique et à la programmation. en C

Initiation. àl algorithmique et à la programmation. en C Initiation àl algorithmique et à la programmation en C Initiation àl algorithmique et à la programmation en C Cours avec 129 exercices corrigés Illustration de couverture : alwyncooper - istock.com Dunod,

Plus en détail