Compléments d algorithmique L1MPCIE

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

Download "Compléments d algorithmique L1MPCIE 2008-2009"

Transcription

1 Compléments d algorithmique L1MPCIE TD4 - Corrections Pointeurs Exercice 1 TYPE pint=^integer; VAR i:integer p1,p2:pint; BEGIN i:=1; p1:=@i; p1^:=2; new(p2); Exercice 2 Liste chaînée par pointeurs Soit L une liste dont chaque élément contient une valeur de type T. 1. Proposer une structure de données pour coder cette liste. TYPE liste = ^élément élément = ENREGISTREMENT val: T suiv: liste FIN ENREGISTREMENT Écrire les sous programmes suivants : 2. Tester si L est vide fonction listevide(donnée L : liste): booléen retourner L = NIL 3. Afficher les éléments de L (itératif, récursif) {itératif} fonction afficher1(donnée L : liste) tant que L NIL faire écrireécran(l^.val) L L^.suiv tant que {récursif} fonction afficher2(donnée L : liste): entier si L NIL alors écrireécran(l^.val) afficher2(l^.suiv) si valeur pointée valeur de i p1 pointe sur p2 pointe sur par p1 (p1^) e (valeur par défaut:0) 1 i 1 2 i 2 2 i 2 (notons-la Var) p2^:=3; 2 i 2 Var 3 p1:=p2; 2 Var 3 Var 3 p1^:=i+2; 2 Var 4 Var 4 dispose(p1); (Rq: p1 et p2 ont un rôle symétrique ici) new(p1); p1^:=5; 2 (valeur par défaut:nil) (valeur par défaut:nil) mémoire non allouée libération mémoire autre iable allouée 2 5 dynamiquement (valeur par défaut:nil) (valeur par défaut:nil) (valeur par défaut:nil) iable allouée dynamiquement (valeur par défaut:nil) (valeur par défaut:nil) valeur pointée par p2 (p2^) mémoire non allouée (ou val par défaut:0) libération mémoire S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 1

2 4. Déterminer la longueur de L (itératif, récursif) {itératif} fonction longueur1(donnée L : liste): entier compteur : entier compteur 0 tant que L NIL faire compteur compteur + 1 L L^.suiv tant que retourner compteur; {récursif} fonction longueur2(donnée L: liste): entier si L = NIL alors retourner 0 retourner 1 + longueur2(l^.suiv) si 5. Ajouter un élément e au de L procédure ajouterentête(donnée e: T, donnée modifiée L: liste) x: liste allouer(x) x^.val e x^.suiv L L x 6. Ajouter un élément e en de L (itératif, récursif) {itératif} procédure ajouterenfin1(donnée e: T, donnée modifiée L: liste) x,tmp : liste si L = NIL alors ajouterentête(e,l) tmp L {pour qu'en sortie L pointe toujours sur la tête} tant que tmp^.suiv NIL faire tmp tmp^.suiv; tant que allouer(x) x^.valeur e; tmp^.suiv x; si {récursif} procédure ajouterenfin2(donnée e: T, donnée modifiée L: liste) x: liste si L = NIL alors allouer(x) S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 2

3 x^.val e x^.suiv NIL L x ajouterenfin2(e, L^.suiv) si 7. Ajouter un élément e à L après le maillon d'adresse adr donnée, ou en de liste si adr n'est pas dans L (récursif) procédure ajouteraprèsadr(donnée e: T, adr: liste, donnée modifiée L : liste) x: liste si L = NIL allouer(x) x^.val e x^.suiv NIL L x si L = adr alors allouer(x) x^.val e x^.suiv L^.suiv L x ajouteraprèsadr(e, adr, L^.suiv) si 8. Tester l'appartenance d'un élément e à la liste L (itératif, récursif) {itératif} fonction appartient1(donnée e: T, L: liste): booléen tant que L NIL faire si l^.val = e alors retourner vrai si L L^.suiv tant que retourner faux; {récursif} fonction appartient2(donnée e: T, L: liste): booléen si L=NIL alors retourner faux si L^.val=e alors retourne vrai retourner appartient2(e, L^.suiv) si 9. Rechercher l'adresse de la première occurrence d'un élément e donné (récursif, itératif) {itératif} fonction rechercher1(donnee e: T, L: liste): liste tant que L NIL faire si L^.val = e alors retourner L S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 3

4 si L L^.suiv tant que retourner NIL; {récursif} fonction rechercher2(donnee e: T, L: liste): liste si L=NIL alors retourner NIL si L^.val=e alors retourner L rechercher2(e, L^.suiv) si 10. Ajouter à L un élément e après la première occurrence d'un élément x donné, ou en de liste si l'élément x n'est pas dans L procédure ajouteraprès1(donnée ajout, occurrence: T, donne modifiée L : liste) x: liste x rechercherx(occurrence, L) ajouteraprèsadr(ajout, x, L) {récursif} procédure ajouteraprès2(donnée ajout, occurrence: T, donne modifiée L : liste) x: liste si L=NIL alors allouer(x) x^.val ajout x^.suiv NIL L x si L^val=occurrence alors allouer(x) x^.val ajout x^.suiv L^.suiv L x ajouteraprès2(ajout, occurrence, L^.suiv) si 11. Supprimer le premier élément de L procédure supprimertête(donne modifiée L: liste) x: liste si L NIL alors x L L L^.suivant libérer(x) si 12. Supprimer un élément de L après le maillon d'adresse p donné (récursif) S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 4

5 procédure supprimeraprèsadr(donnée adr: liste ; donnée modifiée L: liste) x: liste si L NIL alors si L=adr alors si L^.suiv NIL alors x L^.suiv L^.suiv x^.suiv libérer(x) libérer(l) si supprimeraprèsadr(adr, L^.suiv) si si 13. Supprimer la première occurrence d'un élément e de L (itératif, récursif) {itératif} procédure supprimer1(donnée e: T, donnée modifiée L: liste) x,y: liste si L NIL alors si L^.val=e alors {supprimer la tête} x L L L^.suiv libérer(x) y L {pour qu'en sortie L pointe toujours sur la tête} tant que y^.suiv NIIL ET y^.suiv^.val e faire y y^.suiv tant que si y^.suiv NIL faire x y y y^.suiv libérer(x) si si {récursif} procédure supprimer2(donnée e: T, donnée modifiée L: liste) x:liste si L NIL alors si L^.val=e alors x L L L^.suiv libérer(x) supprimer2(e, L^.suiv) si si 14. Vider toute la liste L procédure vider(donnée modifiée L: liste) S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 5

6 tant que L NIL faire supprimertête(l); tant que Exercice 3 Liste d'entiers program ex3; { 1 } type Liste = ^Cellule; Cellule = record valeur : integer; suivant : Liste; { Pour test } procedure initialiser( l: Liste); l := nil; procedure ajouttete( l: Liste; e: integer); t: Liste; new(t); t^.suivant := l; t^.valeur := e; l := t; procedure afficher(l: Liste); if l <> nil then write(l^.valeur, ' '); afficher(l^.suivant); { 2 } function nboccurrences(l: Liste; a: integer): integer; if l = nil then nboccurrences := 0 if l^.valeur = a then nboccurrences := 1 + nboccurrences(l^.suivant, a) nboccurrences := nboccurrences(l^.suivant, a) { 3 } function trieecroissant(l: Liste): boolean; if l = nil then trieecroissant := true if l^.suivant = nil then trieecroissant := true trieecroissant := (l^.valeur < l^.suivant^.valeur) and trieecroissant(l^.suivant) S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 6

7 { 4 } function trieeordreprecis(l: Liste; croissant: boolean): boolean; if l = nil then trieeordreprecis := true if l^.suivant = nil then trieeordreprecis := true trieeordreprecis := ((croissant and (l^.valeur < l^.suivant^.valeur)) or (not(croissant) and (l^.valeur > l^.suivant^.valeur))) and trieeordreprecis(l^.suivant, croissant) function triee(l: Liste): boolean; triee := trieeordreprecis(l, true) or trieeordreprecis(l, false) { 5 } procedure aff1sur2(l: Liste); if l <> nil then write(l^.valeur, ' '); if l^.suivant <> nil then aff1sur2(l^.suivant^.suivant); { 6 } { On décompose, c'est plus simple } {on peut aussi utiliser nboccurences écrite à la question 2} function apparait(l: Liste; e: integer): boolean; if l = nil then apparait := false if l^.valeur = e then apparait := true apparait := apparait(l^.suivant, e) function sansdoublons(l : Liste): boolean; if l = nil then sansdoublons := true if apparait(l^.suivant, l^.valeur) then sansdoublons := false sansdoublons := sansdoublons(l^.suivant) { 7 } { on pourrait aussi appeler un ajoutenqueue à chaque tour de boucle, ce qui a l'avantage d'être plus simple, mais l'inconvénient d'être peu performant, puisque parcours de la liste résultat à chaque ajout de valeur. } procedure fusionlistestriees(l1 : Liste; l2 : Liste; res : Liste); nouvvaleur: integer; dernierecellule: Liste; res := nil; dernierecellule := nil; while (l1 <> nil) or (l2 <> nil) do if (l2 = nil) or ((l1 <> nil) and (l2 <> nil) and (l1^.valeur < l2^.valeur)) then S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 7

8 nouvvaleur := l1^.valeur; l1 := l1^.suivant; end nouvvaleur := l2^.valeur; l2 := l2^.suivant; if (res = nil) then new(res); dernierecellule := res; res^.valeur := nouvvaleur; res^.suivant := nil; end new(dernierecellule^.suivant); dernierecellule := dernierecellule^.suivant; dernierecellule^.valeur := nouvvaleur; dernierecellule^.suivant := nil; { test } l1, l2, l3: Liste; initialiser(l1); ajouttete(l1, 12); ajouttete(l1, 9); ajouttete(l1, 8); initialiser(l2); ajouttete(l2, 14); ajouttete(l2, 10); ajouttete(l2, 2); ajouttete(l2, 1); writeln(triee(l1), triee(l2)); fusionlistestriees(l1, l2, l3); afficher(l3); writeln; end. Exercice 4 File d'attente 1.Écrire une procédure pour initialiser une file qui lui est passée en paramètre. procedure initialiserfifo( f: fifo); f.tete := NIL; f.queue := NIL; 2.Écrire une fonction qui teste si la file est vide. function estvide(f: fifo): boolean; if f.tete = NIL then estvide := true S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 8

9 estvide := false; 3.Écrire une procédure qui affiche une personne, de la forme [nom,prénom] ; et une procédure qui affiche les personnes présentent dans la file d'attente. procedure afficherpersonne(pers: personne); write('[',pers.nom,',',pers.prenom,']'); procedure afficherfifo(f: fifo); e: element; e := f.tete; while e <> NIL do afficherpersonne(e^.valeur); writeln(''); e := e^.suivant; 4.Écrire une procédure qui ajoute une personne dans la file d'attente. {l'ajout dans une FIFO se fait en queue} procedure ajouter(p: personne; f: fifo); nouveau: element; new(nouveau); nouveau^.valeur := p; if estvide(f) then f.tete := nouveau; f.queue^.suivant:= nouveau; f.queue := nouveau; 5.Écrire une fonction qui retourne l'avant dernier élément (s'il existe) de la file d'attente. function avantdernierelement(f: fifo): element; if not estvide(f) then if f.tete = f.queue then {1 seul element} avantdernierelement := NIL; end if f.tete^.suivant = f.queue then avantdernierelement := f.tete f.tete := f.tete^.suivant; avantdernierelement := avantdernierelement(f); end 6.Écrire une procédure qui retourne et enlève une personne de la file d'attente. {Suppression en tête dans une FIFO} procedure enlever( f: fifo; p: personne); S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 9

10 tmp: element; if not estvide(f) then enlever := f.tete^.valeur; tmp := f.tete^.suivant; dispose(f.tete); f.tete:=tmp; end 7.Écrire une fonction qui teste si deux personnes sont identiques. function personnesidentiques(p1,p2: personne): boolean; if (p1.nom=p2.nom) and (p1.prenom=p2.prenom) then personnesidentiques := true personnesidentiques := false; 8.Écrire une fonction qui teste si la file F 1 est incluse dans la file F 2. {test si F1 est inclue dans F2} function estincludans(f1,f2: fifo): boolean; e1,e2: element; sortie: boolean; e1 := f1.tete; e2 := f2.tete; sortie := false; while (e1<>nil) and (e2<>nil) do if personnesidentiques(e1^.valeur, e2^.valeur) then e1 := e1^.suivant; e2 := f2.tete; sortie := true; end e2 := e2^.suivant; sortie := false; estincludans := sortie; 9.Écrire la procédure sauver qui enregistre une file dans un fichier. La file et le nom du fichier (string) sont passés en paramètres. procedure sauver(nomfichier: string ; f: fifo); fichier: fichier_personne; pers: personne; e: element; assign(fichier, nomfichier); rewrite(fichier); {ouverture en écriture} e := f.tete; while e <> NIL do pers := enlever(f); S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 10

11 write(fichier, pers); close(fichier); 10.Écrire la fonction charger qui lit une file sauvegardée dans un fichier, et retourne un élément de type fifo. function charger(nomfichier: string): fifo; fichier: fichier_personne; pers: personne; f: fifo; assign(fichier, nomfichier); reset(fichier); {ouverture en lecture, se placer en } initialiserfifo(f); Repeat read(fichier, pers); ajouter(pers.nom,pers.prenom,f); Until eof (fichier) ; close(fichier); charger := f; Exercice 4 Liste de nombres premiers procedure listepremiers (n: integer; L : liste); L,b: liste; i,j,k: integer; L := NIL; for i:= n downto 2 do ajouterentête (i,l); b := L; k:= b^.contenu; while k*k <= n do for j := k to (n div k) do supprimerx (j*k, L); b := b^.suivant; k := b^.contenu; end. Exercice 5 Arbre binaire de caractères 1.Écrire une procédure qui teste si un noeud est une feuille. function estfeuille(a: arbre): boolean; if a = NIL then estfeuille := false estfeuille := (a^.gauche=nil) and (a^.droite=nil); 2.Écrire une procédure qui affiche les valeurs de l'arbre, selon un parcours infixé (on dit S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 11

12 aussi symétrique). Vous devriez-obtenir : ''D B E A C F'' sur l'exemple ci-dessus. {infixé <=> racine, puis sous-arbre Gauche, puis sous-arbre Droit} procedure afficherinfixe(a: arbre); if a <> NIL then write(a^.valeur,' '); afficherinfixe(a^.gauche); afficherinfixe(a^.droite); 3.Écrire une fonction qui retourne la taille de l'arbre, c-à-d le nombre de noeuds présents dans l'arbre. function taille(a: arbre): integer; {selon un parcours infixé} if a = NIL then taille := 0 taille := 1+ taille(a^.gauche) + taille(a^.droite); 4.Écrire une fonction qui recherche si un caractère est présent dans l'arbre, et retourne l'adresse du noeud. function rechercher(valeur: char ; a: arbre): arbre; tmp : arbre; if a = NIL then rechercher := NIL if a^.valeur=valeur then rechercher := a tmp := rechercher(valeur, a^.gauche); if tmp = NIL then rechercher := rechercher(valeur, a^.droite) rechercher := tmp; 5.Écrire une fonction qui teste si l'arbre est ordonné, c-à-d si la chaîne infixée des valeurs des noeuds correspond à un parcours ordonné croissant. function estordonne(a: arbre): boolean; gauche, droite : arbre; if a = NIL then estordonne := true gauche := a^.gauche; droite := a^.droite; if (gauche<>nil) and (droite<>nil) then estordonne := (gauche^.valeur<=a^.valeur) and (droite^.valeur>=a^.valeur) and estordonne(gauche) and estordonne(droite) S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 12

13 if gauche<>nil then estordonne := (droite^.valeur>=a^.valeur) and estordonne(droite) if droite<>nil then estordonne := gauche^.valeur<=a^.valeur and estordonne(gauche) estordonne := true; 6.Écrire une fonction qui retourne la hauteur de l'arbre, c-à-d le nombre maximum de noeuds rencontrés pour aller de la racine vers une feuille. '0' sera retourné si l'arbre est vide, '1' si l'arbre ne possède qu'un noeud, etc. function max(i,j: integer):integer; if i<j then max:=j max:=i function hauteur(a: arbre): integer; if a = NIL then hauteur := 0 if (a^.gauche=nil) and (a^.droite=nil) then hauteur := 1 hauteur := 1 + max( hauteur(a^.gauche), hauteur(a^.droite) ); 7.Écrire une fonction qui retourne le facteur d'équilibre d'un noeud, c-à-d la différence de la hauteur du sous-arbre gauche avec la hauteur du sous-arbre droit. (QUESTION SUPPRIMEE) function facteurequilibre(a: arbre): integer; if a = NIL then facteurequilibre := 0 facteurequilibre := hauteur(a^.gauche)-hauteur(a^.droite) end 8.Écrire une procédure qui affiche le mot de l'arbre, c-à-d une chaîne formée par les feuilles avec un sens de lecture de gauche à droite. procedure mot(a: arbre); if a <> NIL then if estfeuille(a) then write(a^.valeur) mot(a^.gauche); mot(a^.droite); 9.Écrire une fonction qui teste si l'arbre A 1 est égal à A 2. function estegal(a1,a2: arbre): boolean; {avec un parcours préfixé} S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 13

14 if (a1=nil) and (a2=nil) then estegal := true estegal := false; if (a1<>nil) and (a2<>nil) then if estfeuille(a1) and estfeuille(a2) and (a1^.valeur=a2^.valeur) then estegal := true estegal := false; if (not estfeuille(a1)) and (not estfeuille(a2)) then estegal := estegal(a1^.gauche,a2^.gauche) and estegal(a1^.droite,a2^.droite); S2MPCIE3 Compléments d'algorithmique TD4 Université d'angers 14

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

Arbres binaires de recherche

Arbres binaires de recherche 1 arbre des comparaisons 2 recherche dichotomique l'arbre est recalculé à chaque recherche 2 5 3 4 7 9 1 6 1 2 3 4 5 6 7 9 10 conserver la structure d'arbre au lieu de la reconstruire arbre binaire de

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

EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE

EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE QCM Remarque : - A une question correspond au moins 1 réponse juste - Cocher la ou les bonnes réponses Barème : - Une bonne réponse = +1 - Pas de réponse = 0

Plus en détail

Corrigé des TD 1 à 5

Corrigé des TD 1 à 5 Corrigé des TD 1 à 5 1 Premier Contact 1.1 Somme des n premiers entiers 1 (* Somme des n premiers entiers *) 2 program somme_entiers; n, i, somme: integer; 8 (* saisie du nombre n *) write( Saisissez un

Plus en détail

Examen Médian - 1 heure 30

Examen Médian - 1 heure 30 NF01 - Automne 2014 Examen Médian - 1 heure 30 Polycopié papier autorisé, autres documents interdits Calculatrices, téléphones, traducteurs et ordinateurs interdits! Utilisez trois copies séparées, une

Plus en détail

LES TYPES DE DONNÉES DU LANGAGE PASCAL

LES TYPES DE DONNÉES DU LANGAGE PASCAL LES TYPES DE DONNÉES DU LANGAGE PASCAL 75 LES TYPES DE DONNÉES DU LANGAGE PASCAL CHAPITRE 4 OBJECTIFS PRÉSENTER LES NOTIONS D ÉTIQUETTE, DE CONS- TANTE ET DE IABLE DANS LE CONTEXTE DU LAN- GAGE PASCAL.

Plus en détail

Cours Informatique Master STEP

Cours Informatique Master STEP Cours Informatique Master STEP Bases de la programmation: Compilateurs/logiciels Algorithmique et structure d'un programme Programmation en langage structuré (Fortran 90) Variables, expressions, instructions

Plus en détail

Compression de Données - Algorithme de Huffman Document de Conception

Compression de Données - Algorithme de Huffman Document de Conception ROLLET Samuel SALLE Jennifer Compression de Données - Algorithme de Huffman Document de Conception Projet d'algorithmique et Structure des Données 1 SOMMAIRE 1. Domaine d application....4 1.1 Objectifs

Plus en détail

Programmation avec des objets : Cours 7. Menu du jour

Programmation avec des objets : Cours 7. Menu du jour 1 Programmation avec des objets : Cours 7 Menu du jour 1. Retour sur la classe Liste 2. Précisions sur l interface 3. Difficultés dans le cas d erreurs 4. Soulever des exceptions 5. Utilisation des Listes

Plus en détail

SNT4U16 - Initiation à la programmation 2014-2015. TD - Dynamique de POP III - Fichiers sources

SNT4U16 - Initiation à la programmation 2014-2015. TD - Dynamique de POP III - Fichiers sources SNT4U16 - Initiation à la programmation Licence SVT 2 ème année 2014-2015 TD - Dynamique de POP III - Fichiers sources contacts : mathias.gauduchon@univ-amu.fr, melika.baklouti@univ-amu.fr, xavier.giraud@univ-amu.fr,

Plus en détail

Sub CalculAnnuite() Const TITRE As String = "Calcul d'annuité de remboursement d'un emprunt"

Sub CalculAnnuite() Const TITRE As String = Calcul d'annuité de remboursement d'un emprunt TD1 : traduction en Visual BASIC des exemples du cours sur les structures de contrôle de l'exécution page 1 'TRADUCTION EN VBA DES EXEMPLES ALGORITHMIQUES SUR LES STRUCTURES 'DE CONTROLE DE L'EXECUTION

Plus en détail

Algorithmique & programmation

Algorithmique & programmation Algorithmique & programmation Type structuré Article, Enregistrement, Structure Définition de nouveaux types!! On a vu les types simples "! entier, booléen, caractère, chaîne de caractères!! Comment gérer

Plus en détail

Génie Logiciel avec Ada. 4 février 2013

Génie Logiciel avec Ada. 4 février 2013 Génie Logiciel 4 février 2013 Plan I. Généralités II. Structures linéaires III. Exceptions IV. Structures arborescentes V. Dictionnaires I. Principes II. Notions propres à la POO I. Principes Chapitre

Plus en détail

INF601 : Algorithme et Structure de données

INF601 : Algorithme et Structure de données Cours 2 : TDA Arbre Binaire B. Jacob IC2/LIUM 27 février 2010 Plan 1 Introuction 2 Primitives u TDA Arbin 3 Réalisations u TDA Arbin par cellules chaînées par cellules contiguës par curseurs (faux pointeurs)

Plus en détail

Algorithmes et programmation en Pascal. Cours

Algorithmes et programmation en Pascal. Cours Algorithmes et programmation en Pascal Faculté des Sciences de Luminy Edouard Thiel Cours Deug 1 Mass MA Module de 75 heures 1997 à 2004 2 Algorithmes et programmation en Pascal Edouard Thiel Table des

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

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

Centre CPGE TSI - Safi 2010/2011. Algorithmique et programmation :

Centre CPGE TSI - Safi 2010/2011. Algorithmique et programmation : Algorithmique et programmation : STRUCTURES DE DONNÉES A. Structure et enregistrement 1) Définition et rôle des structures de données en programmation 1.1) Définition : En informatique, une structure de

Plus en détail

Introduction à MATLAB R

Introduction à MATLAB R Introduction à MATLAB R Romain Tavenard 10 septembre 2009 MATLAB R est un environnement de calcul numérique propriétaire orienté vers le calcul matriciel. Il se compose d un langage de programmation, d

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

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

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

Algorithmique et programmation : les bases (VBA) Corrigé

Algorithmique et programmation : les bases (VBA) Corrigé PAD INPT ALGORITHMIQUE ET PROGRAMMATION 1 Cours VBA, Semaine 1 mai juin 2006 Corrigé Résumé Ce document décrit l écriture dans le langage VBA des éléments vus en algorithmique. Table des matières 1 Pourquoi

Plus en détail

Programmation structurée et algorithmes de base en Pascal

Programmation structurée et algorithmes de base en Pascal Programmation structurée et algorithmes de base en Pascal Miage1, IF2, DEUG sciences Patrice Effi BROU UFR Mathématiques et informatique Decembre 2003 Chapitre 1 Sommaire 1 Théorie des langages et compilation

Plus en détail

Ensimag 1ère année Algorithmique 1 Examen 2ième session 24 juin 2010. Algorithmique 1

Ensimag 1ère année Algorithmique 1 Examen 2ième session 24 juin 2010. Algorithmique 1 Algorithmique 1 Durée : 2h Machines électroniques interdites Tous documents papiers autorisés Il est conseillé de traiter les deux parties dans l ordre du sujet. Veuillez respecter les notations introduites

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

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

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

Programmation Objet - Cours II

Programmation Objet - Cours II Programmation Objet - Cours II - Exercices - Page 1 Programmation Objet - Cours II Exercices Auteur : E.Thirion - Dernière mise à jour : 05/07/2015 Les exercices suivants sont en majorité des projets à

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

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

Info0101 Intro. à l'algorithmique et à la programmation. Cours 3. Le langage Java

Info0101 Intro. à l'algorithmique et à la programmation. Cours 3. Le langage Java Info0101 Intro. à l'algorithmique et à la programmation Cours 3 Le langage Java Pierre Delisle, Cyril Rabat et Christophe Jaillet Université de Reims Champagne-Ardenne Département de Mathématiques et Informatique

Plus en détail

ET 24 : Modèle de comportement d un système Boucles de programmation avec Labview.

ET 24 : Modèle de comportement d un système Boucles de programmation avec Labview. ET 24 : Modèle de comportement d un système Boucles de programmation avec Labview. Sciences et Technologies de l Industrie et du Développement Durable Formation des enseignants parcours : ET24 Modèle de

Plus en détail

Correction TD Algorithmique 5.3 Pile - 5.4 Liste 5.3 Pile

Correction TD Algorithmique 5.3 Pile - 5.4 Liste 5.3 Pile Correction TD Algorithmique 5.3 Pile - 5.4 Liste 5.3 Pile Classe Pile var sommet : entier var vals : Tableau Methode Pile() vals nouveau Tableau (?) sommet -1 Methode estvide() :booléen Renvoie

Plus en détail

.NET - Classe de Log

.NET - Classe de Log .NET - Classe de Log Classe permettant de Logger des données Text Dans tous les projets, il est indispensable de pouvoir stocker de l'information textuelle : Pour le suivi des erreurs Pour le suivi de

Plus en détail

SHERLOCK 7. Version 1.2.0 du 01/09/09 JAVASCRIPT 1.5

SHERLOCK 7. Version 1.2.0 du 01/09/09 JAVASCRIPT 1.5 SHERLOCK 7 Version 1.2.0 du 01/09/09 JAVASCRIPT 1.5 Cette note montre comment intégrer un script Java dans une investigation Sherlock et les différents aspects de Java script. S T E M M E R I M A G I N

Plus en détail

STAGE IREM 0- Premiers pas en Python

STAGE IREM 0- Premiers pas en Python Université de Bordeaux 16-18 Février 2014/2015 STAGE IREM 0- Premiers pas en Python IREM de Bordeaux Affectation et expressions Le langage python permet tout d abord de faire des calculs. On peut évaluer

Plus en détail

Programmation VBA/Excel. Programmation VBA. Pierre BONNET. Masters SMaRT & GSI - Supervision Industrielle - 2012-2013 P. Bonnet

Programmation VBA/Excel. Programmation VBA. Pierre BONNET. Masters SMaRT & GSI - Supervision Industrielle - 2012-2013 P. Bonnet Programmation VBA Pierre BONNET 21 La programmation VBA Historiquement, la programmation sous Excel avait comme fonction d'automatiser une succession d'actions faites dans la feuille à l'aide de la souris.

Plus en détail

SYSTÈME DE GESTION DE FICHIERS

SYSTÈME DE GESTION DE FICHIERS SYSTÈME DE GESTION DE FICHIERS - DISQUE 1 Les couches logiciels réponse requête Requêtes E/S Système E/S Pilote E/S Interruptions utilisateur traitement S.E. commandes S.E. S.E. matériel Contrôleur E/S

Plus en détail

chapitre 4 Nombres de Catalan

chapitre 4 Nombres de Catalan chapitre 4 Nombres de Catalan I Dénitions Dénition 1 La suite de Catalan (C n ) n est la suite dénie par C 0 = 1 et, pour tout n N, C n+1 = C k C n k. Exemple 2 On trouve rapidement C 0 = 1, C 1 = 1, C

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

SYSTÈME DE GESTION DE FICHIERS SGF - DISQUE

SYSTÈME DE GESTION DE FICHIERS SGF - DISQUE SYSTÈME DE GESTION DE FICHIERS SGF - DISQUE C.Crochepeyre MPS_SGF 2000-20001 Diapason 1 Les couches logiciels réponse SGF requête matériel matériel Requêtes E/S Système E/S Pilote E/S Interruptions Contrôleur

Plus en détail

Cours d Algorithmique-Programmation 2 e partie (IAP2): programmation 24 octobre 2007impérative 1 / 44 et. structures de données simples

Cours d Algorithmique-Programmation 2 e partie (IAP2): programmation 24 octobre 2007impérative 1 / 44 et. structures de données simples Cours d Algorithmique-Programmation 2 e partie (IAP2): programmation impérative et structures de données simples Introduction au langage C Sandrine Blazy - 1ère année 24 octobre 2007 Cours d Algorithmique-Programmation

Plus en détail

MISE A NIVEAU INFORMATIQUE LANGAGE C - EXEMPLES DE PROGRAMMES. Université Paris Dauphine IUP Génie Mathématique et Informatique 2 ème année

MISE A NIVEAU INFORMATIQUE LANGAGE C - EXEMPLES DE PROGRAMMES. Université Paris Dauphine IUP Génie Mathématique et Informatique 2 ème année 2003-2004 Université Paris Dauphine IUP Génie Mathématique et Informatique 2 ème année MISE A NIVEAU INFORMATIQUE LANGAGE C - EXEMPLES DE PROGRAMMES Maude Manouvrier La reproduction de ce document par

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

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

Rappel. Analyse de Données Structurées - Cours 12. Un langage avec des déclaration locales. Exemple d'un programme

Rappel. Analyse de Données Structurées - Cours 12. Un langage avec des déclaration locales. Exemple d'un programme Rappel Ralf Treinen Université Paris Diderot UFR Informatique Laboratoire Preuves, Programmes et Systèmes treinen@pps.univ-paris-diderot.fr 6 mai 2015 Jusqu'à maintenant : un petit langage de programmation

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

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

UE C avancé cours 1: introduction et révisions

UE C avancé cours 1: introduction et révisions Introduction Types Structures de contrôle Exemple UE C avancé cours 1: introduction et révisions Jean-Lou Desbarbieux et Stéphane Doncieux UMPC 2004/2005 Introduction Types Structures de contrôle Exemple

Plus en détail

L exclusion mutuelle distribuée

L exclusion mutuelle distribuée L exclusion mutuelle distribuée L algorithme de L Amport L algorithme est basé sur 2 concepts : L estampillage des messages La distribution d une file d attente sur l ensemble des sites du système distribué

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

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

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

03/04/2007. Tâche 1 Tâche 2 Tâche 3. Système Unix. Time sharing

03/04/2007. Tâche 1 Tâche 2 Tâche 3. Système Unix. Time sharing 3/4/27 Programmation Avancée Multimédia Multithreading Benoît Piranda Équipe SISAR Université de Marne La Vallée Besoin Programmes à traitements simultanés Réseau Réseau Afficher une animation en temps

Plus en détail

MINISTERE DE L ENSEIGNEMENT TECHNIQUE ET DE LA FORMATION PROFESSIONNELLE. (Pour l obtention du diplôme d analyste programmeur)

MINISTERE DE L ENSEIGNEMENT TECHNIQUE ET DE LA FORMATION PROFESSIONNELLE. (Pour l obtention du diplôme d analyste programmeur) REPUBLIQUE DU SENEGAL Un peuple un but une foi MINISTERE DE L ENSEIGNEMENT TECHNIQUE ET DE LA FORMATION PROFESSIONNELLE DIRECTION DE LA FORMATION PROFESSIONNELLE (Pour l obtention du diplôme d analyste

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

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

PROGRAMMATION EVENEMENTIELLE sur EXCEL

PROGRAMMATION EVENEMENTIELLE sur EXCEL MASTERs SMaRT & GSI PROGRAMMATION EVENEMENTIELLE sur EXCEL Pierre BONNET Programmation évènementielle La programmation évènementielle permet un appel de procédure depuis l'interface HMI d'excel (ou d'un

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

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

EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE

EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE Question 1 : Un câble de catégorie 5 fait référence a : A un câble coaxial fin B un câble coaxial épais C une paire torsadée non blindée (UTP) D une paire torsadée

Plus en détail

Bernard HAMM, Évelyne LAVOISIER

Bernard HAMM, Évelyne LAVOISIER 92 MAÎTRISE DE PROGICIELS DE GESTION DE BASES DE DONNÉES ET DE TRAITEMENT DE TEXTE Compte rendu d'un stage à l'usage des professeurs de sciences sociales. Ce stage a été programmé A la demande et avec

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

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

Cours de Programmation Impérative: Zones de mémoires et pointeurs

Cours de Programmation Impérative: Zones de mémoires et pointeurs Cours de Programmation Impérative: Zones de mémoires et pointeurs Julien David A101 - david@lipn.univ-paris13.fr Julien David (A101 - david@lipn.univ-paris13.fr) 1 / 1 Z`o n`e s `d`e m`é m`o i r`e Julien

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

Expression des contraintes. OCL : Object C o n t r a i n t L a n g u a g e

Expression des contraintes. OCL : Object C o n t r a i n t L a n g u a g e P r o b l é m a t i q u e OCL : O b j e c t C o n s t r a i n t L a n g u a g e Le langage de contraintes d UML Les différents diagrammes d UML permettent d exprimer certaines contraintes graphiquement

Plus en détail

Algorithmique et structures de données I

Algorithmique et structures de données I Algorithmique et structures de données I Riadh Ben Messaoud Université 7 novembre à Carthage Faculté des Sciences Économiques et de Gestion de Nabeul 1ère année Licence Fondamentale IAG 1ère année Licence

Plus en détail

Compilation (INF 564)

Compilation (INF 564) Présentation du cours Le processeur MIPS Programmation du MIPS 1 Compilation (INF 564) Introduction & architecture MIPS François Pottier 10 décembre 2014 Présentation du cours Le processeur MIPS Programmation

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

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

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

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

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

MATLAB : COMMANDES DE BASE. Note : lorsqu applicable, l équivalent en langage C est indiqué entre les délimiteurs /* */.

MATLAB : COMMANDES DE BASE. Note : lorsqu applicable, l équivalent en langage C est indiqué entre les délimiteurs /* */. Page 1 de 9 MATLAB : COMMANDES DE BASE Note : lorsqu applicable, l équivalent en langage C est indiqué entre les délimiteurs /* */. Aide help, help nom_de_commande Fenêtre de travail (Command Window) Ligne

Plus en détail

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

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

Déroulement. Evaluation. Préambule. Définition. Définition. Algorithmes et structures de données 28/09/2009

Déroulement. Evaluation. Préambule. Définition. Définition. Algorithmes et structures de données 28/09/2009 Déroulement Algorithmes et structures de données Cours 1 et 2 Patrick Reuter http://www.labri.fr/~preuter/asd2009 CM mercredi de 8h00 à 9h00 (Amphi Bât. E, 3 ème étage) ED - Groupe 3 : mercredi, 10h30

Plus en détail

Adama MBODJI MBODJ.SYSTEM

Adama MBODJI MBODJ.SYSTEM MBODJ.SYSTEM Tableaux & vecteurs Algorithmes de tris Chaînes de caractères Listes linéaires Piles & Files Arbres Fichiers Je dédie cet ouvrage à mon père Souleymane MBODJI 2 Dédicace... 2 Sommaire... 3

Plus en détail

1. Structure d'un programme FORTRAN 95

1. Structure d'un programme FORTRAN 95 FORTRAN se caractérise par la nécessité de compiler les scripts, c'est à dire transformer du texte en binaire.(transforme un fichier de texte en.f95 en un executable (non lisible par un éditeur) en.exe.)

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

Initiation à LabView : Les exemples d applications :

Initiation à LabView : Les exemples d applications : Initiation à LabView : Les exemples d applications : c) Type de variables : Créer un programme : Exemple 1 : Calcul de c= 2(a+b)(a-3b) ou a, b et c seront des réels. «Exemple1» nom du programme : «Exemple

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

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

Introduction à la programmation concurrente

Introduction à la programmation concurrente Introduction à la programmation concurrente Moniteurs Yann Thoma Reconfigurable and Embedded Digital Systems Institute Haute Ecole d Ingénierie et de Gestion du Canton de Vaud This work is licensed under

Plus en détail

Application 1- VBA : Test de comportements d'investissements

Application 1- VBA : Test de comportements d'investissements Application 1- VBA : Test de comportements d'investissements Notions mobilisées Chapitres 1 à 5 du cours - Exemple de récupération de cours en ligne 1ère approche des objets (feuilles et classeurs). Corps

Plus en détail

Systemes d'exploitation des ordinateurs

Systemes d'exploitation des ordinateurs ! " #$ % $ &' ( $ plan_ch6_m1 Systemes d'exploitation des ordinateurs Conception de Systèmes de Gestion de la Mémoire Centrale Objectifs 1. Conception de systèmes paginés 2. Conception des systèmes segmentés

Plus en détail

KL5121. Pour activer des sorties en fonction de la position d'un codeur

KL5121. Pour activer des sorties en fonction de la position d'un codeur KL5121 Pour activer des sorties en fonction de la position d'un codeur VERSION : 1.0 / PH DATE : 07 Février 2006 Sommaire Ce manuel explique de manière pratique les étapes successives pour mettre en œuvre

Plus en détail

Algorithmes récursifs

Algorithmes récursifs Licence 1 MASS - Algorithmique et Calcul Formel S. Verel, M.-E. Voge www.i3s.unice.fr/ verel 23 mars 2007 Objectifs de la séance 3 écrire des algorithmes récursifs avec un seul test rechercher un élément

Plus en détail

Cours de Systèmes d Exploitation

Cours de Systèmes d Exploitation Licence d informatique Synchronisation et Communication inter-processus Hafid Bourzoufi Université de Valenciennes - ISTV Introduction Les processus concurrents s exécutant dans le système d exploitation

Plus en détail

1. Structure d un programme C. 2. Commentaire: /*..texte */ On utilise aussi le commentaire du C++ qui est valable pour C: 3.

1. Structure d un programme C. 2. Commentaire: /*..texte */ On utilise aussi le commentaire du C++ qui est valable pour C: 3. 1. Structure d un programme C Un programme est un ensemble de fonctions. La fonction "main" constitue le point d entrée pour l exécution. Un exemple simple : #include int main() { printf ( this

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

Algorithmique et Programmation

Algorithmique et Programmation École Supérieure d Ingénieurs de Poitiers Gea Algorithmique et Programmation Laurent Signac ii Algorithmique et programmation Gea Table des matières Avant Propos v Structures de données Notion de pointeur..............................................

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

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

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

Programmation Orientée Objet Java

Programmation Orientée Objet Java Programmation Orientée Objet Java Bertrand Estellon Département Informatique et Interactions Aix-Marseille Université 12 novembre 2014 Bertrand Estellon (DII AMU) Programmation Orientée Objet Java 12 novembre

Plus en détail