GPA777 (Codage C++) 2

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

Download "GPA777 (Codage C++) 2"

Transcription

1 Exemple de codage C++ Classe Rationnel Rôle Cette classe modélise les nombres rationnels. Raison - Le domaine du problème est simple à comprendre. - Présenter les techniques de programmation C++: Déclaration d une classe Définition d une classe Surcharge des opérateurs Utilisation de la classe - La conception est fort simple. - Montrer les subtilités de la programmation C++: Établissement des constructeurs Conversion implicite de type Conversion explicite de type GPA777 (Codage C++) 1 Nombre rationnel Il est composé d un numérateur (n) et d un dénominateur (d) avec n, d ℵ et d 0. Les calculs par nombres rationnels sont d une grande précision par rapport à la représentation en point flottant. Notre implantation Les opérateurs binaires +, -, * et /. Les opérateurs +=, -=, *= et /= (Pour faciliter leur utilisation dans un programme C++) L opérateur d assignation = Rationnel rat1, rat2; : : : rat1 = 12345; rat2 = rat1; Les opérateurs relationnels ==, <, >,, Les opérateurs unaires + et -. GPA777 (Codage C++) 2 1

2 Notre implantation Les fonctions membres pour retourner le numérateur, le dénominateur du nombre rationnel. Les opérateurs pré (et post) incrémentation (et décrémentation) ++, --. Rationnel rat; : : : rat++; ++rat; --rat; rat-- Les opérateurs de conversion de type. (invoqués implicitement par le compilateur ou explicitement par le programmeur) Les opérateurs non-linéaires: (valeur absolue), é ù (ceil), ë û (floor). (Ces opérateurs retournent un nombre en point flottant sauf ) L opérateur d insertion de flux de sortie <<. (Pour afficher le contenu d un nombre rationnel à la sortie standard) GPA777 (Codage C++) 3 Scénarios d utilisation Déterminer l utilisation de la classe afin d établir les constructeurs nécessaires. Utilisation standard: Rationnel rat; (Régler le dénominateur à 1 pour éliminer la possibilité de division par 0) Création à partir d un numérateur (et d un dénominateur): Rationnel rat(17, 13); Rationnel rat(17); (Régler le dénominateur à 1 pour éliminer la possibilité de division par 0) Création à partir d un autre objet de type Rationnel: Rationnel rat1(17, 13); Rationnel rat2(rat1); GPA777 (Codage C++) 4 2

3 Déclaration de la classe La déclaration sert à indiquer le contenu des classes. Elle sert aussi à déclarer les constantes, les variables et les fonctions (prototypes) à exporter. La déclaration d une classe s effectue dans un fichier.h ou dans un fichier.cpp Fichier.h est appelé fichier d en-tête (header file) Fichier.cpp est le fichier source (corps) et sert à définir une classe Lorsque la classe est simple à créer ou à utiliser, on peut la déclarer dans un fichier.cpp en même temps que sa définition. Pour l implantation de notre classe Rationnel, nous déclarerons son contenu dans un fichier nommé Rationnel.h GPA777 (Codage C++) 5 Déclaration de la classe (Ce projet de programmation est disponible sur la page Web du cours) #if!defined(_rationnel_h) #define _RATIONNEL_H // Wrapper de protection class Rationnel public: // 1) Constructeur par défaut Rationnel() : num(0), den(1) // 2) Constructeur acceptant le numérateur et le dénominateur // n = numérateur, d = dénominateur Rationnel(long n, long d = 1); // 3) Constructeur acceptant un nombre rationnel (rhs = right // hand side) Rationnel(const Rationnel& rhs) : num(rhs.num), den(rhs.den) /* Destructeur: Il ne peut y avoir qu'un seul destructeur par classe. ~Rationnel() GPA777 (Codage C++) 6 3

4 /* Opérateurs d'assignation: Parce que l'on veut pouvoir écrire des assignations de la forme x = y où x est un objet de type Rationnel et y une valeur ou un autre objet de type Rationnel. Rationnel& operator=(const Rationnel& rhs) num = rhs.num; den = rhs.den; return (*this); Rationnel& operator=(long rhs) num = rhs; den = 1; return (*this); /* Fonctions d'accès aux données: Pour obtenir des données de cette classe. Note: Le modificateur "const" indique au compilateur que la fonction ne modifie pas les attributs de l'objet (fonction à lecture seulement). long numerateur(void) const return num; long denominateur(void) const return den; GPA777 (Codage C++) 7 /* Opérateurs unaires: Pour réaliser les opérations telles +x, -x, etc. où x est un objet de la classe Rationnel. Rationnel operator+(void) const // Rappelez-vous -x = (-numérateur)/denominateur lorsque // x est un nombre rationnel. Rationnel operator-(void) const return Rationnel(-num, den); // x = numérateur / denominateur, // inverse(x) = denominateur/numérateur Rationnel inverse(void) const return Rationnel(den, num); /* Opérateurs binaires: Pour réaliser les opérations telles x += y, x-= y où x est un objet de type Rationnel, y est un nombre ou un objet de type Rationnel. const Rationnel& operator+=(const Rationnel& rhs); // addition const Rationnel& operator-=(const Rationnel& rhs); // soustraction const Rationnel& operator*=(const Rationnel& rhs); // multiplication const Rationnel& operator/=(const Rationnel& rhs); // division const Rationnel& operator+=(long rhs); // addition const Rationnel& operator-=(long rhs); // soustraction const Rationnel& operator*=(long rhs); // multiplication const Rationnel& operator/=(long rhs); // division GPA777 (Codage C++) 8 4

5 /* Opérateurs incrémental et décrémental: Pour réaliser les opérations telles ++x, --x (pré), x++, x-- (post) où x est un objet de type Rationnel. const Rationnel& operator++(); // pré const Rationnel operator++(int); // post const Rationnel& operator--(); // pré const Rationnel operator--(int); // post /* Opérateurs de conversion: L'idée est de permet le "typecasting" style C (ex: double(x) où x est un objet de type Rationnel. Aussi, pour les conversions implicites réalisées par le compilateur: d = x + y, où d est un type double (par exemple), x et y du type Rationnel. operator double(void) const return double(num)/den; private: /* Attributs et opérations privés de la classe long num; // numérateur long den; // dénominateur long gcd(long, long);// fonction (plus grand diviseur commun) ; // Fin de la classe Rationnel GPA777 (Codage C++) 9 Dans le même fichier en-tête, nous déclarons également les fonctions utilitaires suivantes: /* /* Fonctions utilitaires et autres qui sont utiles pour nous /* // Conversion explicite Rationnel -> double. Le mot clé inline // veut dire, copier la fonction directement au point d'utilisation. // Donc, plus rapide qu'un appel de fonction. inline double versdouble(const Rationnel& r) return double(r.numerateur())/r.denominateur(); // conversion explicite double -> Rationnel Rationnel versrationnel(double x, int iterations = 5); // Opérateurs mathématiques élémentaires: Pour réaliser la troncature, //l'arrondissement, etc. inline long trunc(const Rationnel& r) return r.numerateur() / r.denominateur(); GPA777 (Codage C++) 10 5

6 inline long floor(const Rationnel& r) long q = r.numerateur() / r.denominateur(); return (r.numerateur() < 0 && r.denominateur()!= 1)? --q : q; inline long ceil(const Rationnel& r) long q = r.numerateur() / r.denominateur(); return (r.numerateur() >= 0 && r.denominateur()!= 1)? ++q : q; // Opérateurs binaires: Pour réaliser les opérations telles // x + y, x - y où x, y est un objet de type Rationnel, y est un // nombre ou un objet de type Rationnel. const Rationnel operator+(const Rationnel& gauche, const Rationnel& droite); const Rationnel operator-(const Rationnel& gauche, const Rationnel& droite); const Rationnel operator*(const Rationnel& gauche, const Rationnel& droite); const Rationnel operator/(const Rationnel& gauche, const Rationnel& droite); // Opérateurs relationnels: Pour réaliser les opérations de comparaison // telles x < y, x > y, etc. bool operator==(const Rationnel& gauche, Rationnel& droite); bool operator!=(const Rationnel& gauche, Rationnel& droite); bool operator<=(const Rationnel& gauche, Rationnel& droite); bool operator>=(const Rationnel& gauche, Rationnel& droite); bool operator<(const Rationnel& gauche, Rationnel& droite); bool operator>(const Rationnel& gauche, Rationnel& droite); GPA777 (Codage C++) 11 // Opérateur d'insertion pour flux de sortie: Pour réaliser l'opération // cout << x où cout est le flux de sortie standard et x est un objet // de type Rationnel. ostream& operator<<(ostream& s, const Rationnel& r); // Valeur absolue d'un nombre rationnel Rationnel rabs(const Rationnel& rat); #endif // Fin du wrapper Nous avons implanté les opérateurs +, -, * et / par des fonctions exportées au lieu des fonctions membres de la classe. On peut ainsi profiter de l existence des opérateurs +=, -=, *= et /= déjà définis dans la classe Rationnel. GPA777 (Codage C++) 12 6

7 Définition de la classe La définition est l implantation des opérations d une classe. Elle sert aussi à donner l implantation des fonctions à exporter. La définition d une classe s effectue dans un fichier.cpp en utilisant les instructions légales de C et de C++. Pour permettre au compilateur de vérifier les types (type checking) utilisés dans notre programme, il est nécessaire d inclure le fichier d en-tête Rationnel.h dans le fichier Rationnel.cpp Il faut également inclure les en-têtes appropriés pour les classes et fonctions utilisées qui ne sont pas du même module. GPA777 (Codage C++) 13 Définition de la classe (Ce projet de programmation est disponible sur la page Web du cours) #include "stdafx.h" #include <stdlib.h> #include <math.h> #include <iostream.h> #include <limits> #include "Rationnel.h" // Pour la précompilation des en-têtes VC++ // exit(), etc. // pour les fonctions mathématiques // pour les flux d'entrée/sortie // grandeurs limites des nombres (Standard C++ lib) // en-tête de notre classe using namespace std; // Espace de nom pour le standard C++ Library Rationnel::Rationnel(long n, long d) if (d == 0L) cerr << "Dénominateur nul" << endl; exit(1); // Le signe est toujours placé sur le numérateur // Ça simplifie le traitement if (d < 0L) n = -n; d = -d; if (n == 0L) num = 0L; den = 1L; GPA777 (Codage C++) 14 7

8 else // Les nombres rationnels sont gardés sous forme // normalisée. long g = gcd(n, d); num = n/g; den = d/g; // fin du constructeur Rationnel() long Rationnel::gcd(long u, long v) long tmp, a = labs(u), b = labs(v); if (b > a) tmp = a; a = b; b = tmp; for (; ;) if (b == 0L) return a; else if (b == 1L) return b; else tmp = b; b = a % b; a = tmp; // fin de gcd() GPA777 (Codage C++) 15 const Rationnel& Rationnel::operator+=(const Rationnel& rhs) long g1 = gcd(den, rhs.den); if (g1 == 1L) num = num * rhs.den + den * rhs.num; den = den * rhs.den; else long t = num * (rhs.den/g1) + (den/g1) * rhs.num; long g2 = gcd(t, g1); num = t/g2; den = (den/g1) * (rhs.den/g2); // fin de operator+= const Rationnel& Rationnel::operator+=(long rhs) num = num + den * rhs; // fin de operator+= const Rationnel operator+(const Rationnel& gauche, const Rationnel& droite) return Rationnel(gauche) += droite; // fin de operator+ Fonction utilitaire (non membre) GPA777 (Codage C++) 16 8

9 const Rationnel& Rationnel::operator-=(const Rationnel& rhs) long g1 = gcd(den, rhs.den); if (g1 == 1L) num = num * rhs.den - den * rhs.num; den = den * rhs.den; else long t = num * (rhs.den/g1) - (den/g1) * rhs.num; long g2 = gcd(t, g1); num = t/g2; den = (den/g1) * (rhs.den/g2); // fin de operator-= const Rationnel& Rationnel::operator-=(long rhs) num = num - den * rhs; // fin de operator-= const Rationnel operator-(const Rationnel& gauche, const Rationnel& droite) return Rationnel(gauche) -= droite; // fin de operator- Fonction utilitaire (non membre) GPA777 (Codage C++) 17 const Rationnel& Rationnel::operator-=(const Rationnel& rhs) long g1 = gcd(den, rhs.den); if (g1 == 1L) num = num * rhs.den - den * rhs.num; den = den * rhs.den; else long t = num * (rhs.den/g1) - (den/g1) * rhs.num; long g2 = gcd(t, g1); num = t/g2; den = (den/g1) * (rhs.den/g2); // fin de operator-= const Rationnel& Rationnel::operator-=(long rhs) num = num - den * rhs; // fin de operator-= const Rationnel operator-(const Rationnel& gauche, const Rationnel& droite) return Rationnel(gauche) -= droite; // fin de operator- Fonction utilitaire (non membre) GPA777 (Codage C++) 18 9

10 const Rationnel& Rationnel::operator*=(const Rationnel& rhs) long g1 = gcd(num, rhs.den); long g2 = gcd(den, rhs.num); num = (num/g1) * (rhs.num/g2); den = (den/g2) * (rhs.den/g1); // fin de operator*= const Rationnel& Rationnel::operator*=(long rhs) long g = gcd(den, rhs); num *= rhs/g; den /= g; // fin de operator*= const Rationnel operator*(const Rationnel& gauche, const Rationnel& droite) return Rationnel(gauche) *= droite; // fin de operator* Fonction utilitaire (non membre) GPA777 (Codage C++) 19 const Rationnel& Rationnel::operator*=(const Rationnel& rhs) long g1 = gcd(num, rhs.den); long g2 = gcd(den, rhs.num); num = (num/g1) * (rhs.num/g2); den = (den/g2) * (rhs.den/g1); // fin de operator*= const Rationnel& Rationnel::operator*=(long rhs) long g = gcd(den, rhs); num *= rhs/g; den /= g; // fin de operator*= const Rationnel operator*(const Rationnel& gauche, const Rationnel& droite) return Rationnel(gauche) *= droite; // fin de operator* Fonction utilitaire (non membre) GPA777 (Codage C++) 20 10

11 const Rationnel& Rationnel::operator/=(const Rationnel& rhs) if (rhs == 0.0) cerr << "Division par zéro" << endl; exit(1); long g1 = gcd(num, rhs.num); long g2 = gcd(den, rhs.den); num = (num/g1) * (rhs.den/g2); den = (den/g2) * (rhs.num/g1); // Toujours mettre le signe au numérateur if (den < 0L) num = -num; den = -den; // fin de operator/= const Rationnel& Rationnel::operator/=(long rhs) if (rhs == 0L) cerr << "Division par zéro" << endl; exit(1); long g = gcd(num, rhs); num /= g; den *= rhs/g; // Toujours mettre le signe au numérateur if (den < 0L) num = -num; den = -den; // fin de operator/= GPA777 (Codage C++) 21 const Rationnel operator/(const Rationnel& gauche, const Rationnel& droite) return Rationnel(gauche) /= droite; // fin de operator/ const Rationnel& Rationnel::operator ++() return (*this += 1); // fin de operator ++ const Rationnel& Rationnel::operator --() return (*this -= 1); // fin de operator -- const Rationnel Rationnel::operator ++(int) Rationnel valeur = *this; ++(*this); return (valeur); // fin de operator ++ Pré-incrémentation Pré-décrémentation Post-incrémentation GPA777 (Codage C++) 22 11

12 const Rationnel Rationnel::operator --(int) Rationnel valeur = *this; --(*this); return (valeur); // fin de operator -- bool operator==(const Rationnel& gauche, Rationnel& droite) return (gauche.numerateur() == droite.numerateur() && gauche.denominateur() == droite.denominateur()); // fin de operator == bool operator!=(const Rationnel& gauche, Rationnel& droite) return (gauche.numerateur()!= droite.numerateur() && gauche.denominateur()!= droite.denominateur()); // fin de operator!= bool operator<(const Rationnel& gauche, Rationnel& droite) return (versdouble(gauche) < versdouble(droite)); // fin de operator < Post-décrémentation Fonctions utilitaires (non membre) GPA777 (Codage C++) 23 bool operator>(const Rationnel& gauche, Rationnel& droite) return (versdouble(gauche) > versdouble(droite)); // fin de operator > bool operator<=(const Rationnel& gauche, Rationnel& droite) return ((gauche < droite) (gauche == droite)); // fin de operator <= bool operator>=(const Rationnel& gauche, Rationnel& droite) return ((gauche > droite) (gauche == droite)); // fin de operator >= Rationnel rabs(const Rationnel& rat) if (rat.numerateur() < 0) return -rat; else return rat; Fonctions utilitaires (non membre) // fin de rabs() GPA777 (Codage C++) 24 12

13 ostream& operator<<(ostream& s, const Rationnel& r) if (r.denominateur() == 1L) s << r.numerateur(); else s << r.numerateur() << "/" << r.denominateur(); return s; // fin de << C est de cette façon que l on surcharge l opérateur << (insertion dans le flux de sortie). Ex: Rationnel rat(11, 5); : : : cout << rat << endl; GPA777 (Codage C++) 25 /* versrationnel ******************************************** * Fonction locale réalisant la conversion double -> * Rationnel. Méthode utilisée est la fraction continue. * Ex: 1 * * = = = * * * * * * * Il y aura toujours perte de précision mais c'est simple à * réaliser. * * Entrée: x (valeur double), limite, iterations * Sortie: un objet de type Rationnel * static Rationnel versrationnel(double x, double limite, int iterations) double partieentiere, partiefractionnaire = modf(x, &partieentiere); double d = 1.0 / partiefractionnaire; Conversion explicite de double vers Rationnel long reste = long(partieentiere); if (d > limite iterations == 0) return Rationnel(reste); else return Rationnel(reste) + versrationnel(d, limite *.1, --iterations).inverse(); GPA777 (Codage C++) 26 13

14 /* versrationnel ******************************************** * Fonction locale réalisant la conversion double -> * Rationnel * * Entrée: x (valeur double), iterations * Sortie: un objet de type Rationnel * static Rationnel versrationnel(double x, int iterations) if (x == 0.0 x < numeric_limits<long>::min() x > numeric_limits<long>::max()) return Rationnel(0, 1); else long signe = x < 0.0? -1 : 1; return Rationnel(signe) * versrationnel(signe * x, 1.0e12, iterations); // fin de versrationnel() La définition des fonctions membres et des fonctions utilitaires est maintenant terminée. GPA777 (Codage C++) 27 Utilisation de la classe Rationnel Génération d une série harmonique: /* Harmonique ********************************************** * Une série harmonique est définie par: H(n) = 1 + 1/2 + * 1/3 + 1/n. En exprimant ces valeurs en terme de nombres * rationnels, nous aurons une précision arbitraire. * * Entrée: n de la série harmonique * Sortie: Rationnel résultant * Rationnel Harmonique(int n) Rationnel rat = 1; for (int i=2; i<=n; i++) rat += Rationnel(1, i); return rat; // fin Harmonique() H n = L GPA777 (Codage C++) 28 n 14

15 Utilisation de la classe Rationnel Approximation de la constante de Euler par une série harmonique void TestHarmonique() cout << "n\tapproximation Euler\tHarmonique(n)" << endl; cout << "========================================" << endl; for (int n=1; n<25; n++) Rationnel r = Harmonique(n); double g = versdouble(r) - log(n); g -= (1.0/(2*n)) * (1.0 - (1.0/(6*n))); cout << n << '\t' << g << '\t' << r << endl; // fin de TestHarmonique() n Euler harmonique(n) n Euleur harmonique(n) ======================================================================================== / / / / / / / / / / / / / / / / / / / / / / / GPA777 (Codage C++) 29 Utilisation de la classe Rationnel Génération des nombres Bernoulli: æ n 1 1 = ç ( 1), 1. å n B ç n B k n + B = 0 è k= 0 è k ø ø Rationnel Binomial(int n, int k) if (n < 0) cerr << "n ne peut etre negatif" << endl; exit (1); if (k < 0 k > n) cerr << "k ne peut etre negatif ou plus grand que n" << endl; exit (1); if (k > n-k) æ n ö æ n ö æ n ö k = n-k; ç = n k + 1 k ç, ç = 1 if (k == 0) return 1; 1 è kø è k ø è kø k= 0 return Rationnel(n-k+1, k) * Binomial(n, k-1); // fin de Binomial() æ + ö ö ( ). GPA777 (Codage C++) 30 15

16 Utilisation de la classe Rationnel Génération des nombres Bernoulli (suite) Rationnel Bernoulli(int n) if (n < 0) cerr << "indice ne peut etre negatif" << endl; exit(1); else if (n == 0) return 1; else if (n == 1) return Rationnel(-1, 2); if (n % 2) return Rationnel(0, 1); Rationnel r = 0; for (int k=0; k<n; k++) r -= Binomial(n+1, k) * Bernoulli(k); r /= n+1; return r; // fin de Bernouilli() GPA777 (Codage C++) 31 Utilisation de la classe Rationnel Génération des nombres Bernoulli (suite) void TestBernoulli() cout << "n\tbernoulli(n)" << endl; cout << "====================" << endl; Rationnel b; for (int n=0; n<23; n++) if ((b=bernoulli(n))!= 0.0) cout << n << '\t' << b << endl; // fin de TestBernoulli() n Bernoulli(n) n Bernoulli(n) ============================================== / / / / / / / /42 8-1/ / / /6 GPA777 (Codage C++) 32 16

17 Environnement de développement Nous avons utilisé le VC++ 6 pour la programmation de cette classe. Le projet de programmation est du type «Win32 console application». Les fichiers créés sont rangés de cette façon: Rationnel.h (.cpp): déclaration et définition de la classe Rationnel. ProgPrincipal.cpp: fonction main() et les routines pour l approximation de constante d Euler et la génération des nombres de Bernoulli. StdAfx.h (.cpp): fichiers nécessaires pour la précompilation des fichiers d en-tête de VC++. ReadMe.txt: description du contenu de ce projet de programmation. Page web: GPA777 (Codage C++) 33 17

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

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

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

TD Objets distribués n 3 : Windows XP et Visual Studio.NET. Introduction à.net Remoting

TD Objets distribués n 3 : Windows XP et Visual Studio.NET. Introduction à.net Remoting IUT Bordeaux 1 2005-2006 Département Informatique Licence Professionnelle ~ SI TD Objets distribués n 3 : Windows XP et Visual Studio.NET Introduction à.net Remoting Partie 1 : l'analyseur de performances

Plus en détail

I. Introduction aux fonctions : les fonctions standards

I. Introduction aux fonctions : les fonctions standards Chapitre 3 : Les fonctions en C++ I. Introduction aux fonctions : les fonctions standards A. Notion de Fonction Imaginons que dans un programme, vous ayez besoin de calculer une racine carrée. Rappelons

Plus en détail

INFO-F-105 Language de programmation I Séance VI

INFO-F-105 Language de programmation I Séance VI INFO-F-105 Language de programmation I Séance VI Jérôme Dossogne Année académique 2008 2009 Un grand merci à Yves Roggeman pour ses relectures et remarques des codes et commentaires qui ont contribuées

Plus en détail

Programme Compte bancaire (code)

Programme Compte bancaire (code) using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; Programme Compte bancaire (code) namespace compte_bancaire /// Classe Program public

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

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

Le langage C++ est un langage de programmation puissant, polyvalent, on serait presque tenté de dire universel, massivement utilisé dans l'industrie

Le langage C++ est un langage de programmation puissant, polyvalent, on serait presque tenté de dire universel, massivement utilisé dans l'industrie Chapitre I : Les bases du C++ Le langage C++ est un langage de programmation puissant, polyvalent, on serait presque tenté de dire universel, massivement utilisé dans l'industrie du logiciel, et ce depuis

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

Claude Delannoy. 3 e édition C++

Claude Delannoy. 3 e édition C++ Claude Delannoy 3 e édition Exercices Exercices C++ en en langage langage delc++ titre 4/07/07 15:19 Page 2 Exercices en langage C++ AUX EDITIONS EYROLLES Du même auteur C. Delannoy. Apprendre le C++.

Plus en détail

Introduction à la programmation Travaux pratiques: séance d introduction INFO0201-1

Introduction à la programmation Travaux pratiques: séance d introduction INFO0201-1 Introduction à la programmation Travaux pratiques: séance d introduction INFO0201-1 B. Baert & F. Ludewig Bruno.Baert@ulg.ac.be - F.Ludewig@ulg.ac.be Qu est-ce que la programmation? Programmer Ecrire un

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

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 d Algorithmique et de Langage C 2005 - v 3.0

Cours d Algorithmique et de Langage C 2005 - v 3.0 Cours d Algorithmique et de Langage C 2005 - v 3.0 Bob CORDEAU cordeau@onera.fr Mesures Physiques IUT d Orsay 15 mai 2006 Avant-propos Avant-propos Ce cours en libre accès repose sur trois partis pris

Plus en détail

Introduction au langage C

Introduction au langage C Introduction au langage C Cours 1: Opérations de base et premier programme Alexis Lechervy Alexis Lechervy (UNICAEN) Introduction au langage C 1 / 23 Les premiers pas Sommaire 1 Les premiers pas 2 Les

Plus en détail

Plan Pédagogique du cours

Plan Pédagogique du cours Plan Pédagogique du cours Module: Programmation Orientée Objet Section : informatique Niveau : 3 ème niveau (gestion, industriel, réseau) Volume Horaire : 22,5 heures Cours Intégrés + 45 Travaux Pratiques

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

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

Cours Programmation Système

Cours Programmation Système Cours Programmation Système Filière SMI Semestre S6 El Mostafa DAOUDI Département de Mathématiques et d Informatique, Faculté des Sciences Université Mohammed Premier Oujda m.daoudi@fso.ump.ma Février

Plus en détail

Quelques éléments de compilation en C et makefiles

Quelques éléments de compilation en C et makefiles Quelques éléments de compilation en C et makefiles Guillaume Feuillade 1 Compiler un programme C Le principe de la compilation consiste à passer d un ensemble de fichiers de code à un programme exécutable

Plus en détail

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars 2014. http://homepages.laas.fr/matthieu/cours/java/java.pdf

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars 2014. http://homepages.laas.fr/matthieu/cours/java/java.pdf Introduction à Java Matthieu Herrb CNRS-LAAS http://homepages.laas.fr/matthieu/cours/java/java.pdf Mars 2014 Plan 1 Concepts 2 Éléments du langage 3 Classes et objets 4 Packages 2/28 Histoire et motivations

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

C++ COURS N 2 : CLASSES, DONNÉES ET FONCTIONS MEMBRES Classes et objets en C++ Membres d'une classe Spécification d'une classe Codage du comportement

C++ COURS N 2 : CLASSES, DONNÉES ET FONCTIONS MEMBRES Classes et objets en C++ Membres d'une classe Spécification d'une classe Codage du comportement C++ COURS N 2 : CLASSES, DONNÉES ET FONCTIONS MEMBRES Classes et objets en C++ Membres d'une classe Spécification d'une classe Codage du comportement des objets d'une classe Utilisation d'une classe Droit

Plus en détail

Introduction à l héritage en C++

Introduction à l héritage en C++ Algorithmique/Langage 1ère année Introduction à l héritage en C++ Yacine BELLIK IUT d Orsay Yacine.Bellik@iut-orsay.fr 1 Bibliographie Ce cours est basé sur le livre suivant : Programmer en C++, 5ème édition

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

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

LE LANGAGE C++ ENAC 1997 A. DANCEL

LE LANGAGE C++ ENAC 1997 A. DANCEL LE LANGAGE C++ ENAC 1997 A. DANCEL 1 - GENERALITES "L'homme se découvre quand il se mesure avec l'objet." Antoine de Saint-Exupéry, Terre des hommes 1.1 INTRODUCTION Ce cours est conçu pour permettre aux

Plus en détail

INTRODUCTION AUX SYSTEMES D EXPLOITATION. TD2 Exclusion mutuelle / Sémaphores

INTRODUCTION AUX SYSTEMES D EXPLOITATION. TD2 Exclusion mutuelle / Sémaphores INTRODUCTION AUX SYSTEMES D EXPLOITATION TD2 Exclusion mutuelle / Sémaphores Exclusion mutuelle / Sémaphores - 0.1 - S O M M A I R E 1. GENERALITES SUR LES SEMAPHORES... 1 1.1. PRESENTATION... 1 1.2. UN

Plus en détail

Programmation C++ (débutant)/instructions for, while et do...while

Programmation C++ (débutant)/instructions for, while et do...while Programmation C++ (débutant)/instructions for, while et do...while 1 Programmation C++ (débutant)/instructions for, while et do...while Le cours du chapitre 4 : le for, while et do...while La notion de

Plus en détail

Programmation en C/C++

Programmation en C/C++ INSA de Lyon Département Génie Electrique Module IF1,IF3,IF4 Programmation en C/C++ Thomas Grenier Nicolas Ducros Tanneguy Redarce Lyon, le 3 mars 2015 2 / 63 Table des matières 1 Développement en C++

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

TP1 : Initiation à Java et Eclipse

TP1 : Initiation à Java et Eclipse TP1 : Initiation à Java et Eclipse 1 TP1 : Initiation à Java et Eclipse Systèmes d Exploitation Avancés I. Objectifs du TP Ce TP est une introduction au langage Java. Il vous permettra de comprendre les

Plus en détail

Département Automatisation et Informatisation Année 2005-2006. Programmation en C++ Institut des Sciences et Techniques de l Ingénieur d Angers

Département Automatisation et Informatisation Année 2005-2006. Programmation en C++ Institut des Sciences et Techniques de l Ingénieur d Angers Département Automatisation et Informatisation Année 2005-2006 Programmation en C++ Institut des Sciences et Techniques de l Ingénieur d Angers 1 Bertrand Cottenceau 1. Introduction du cours de C++...3

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

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

C++ Programmer. en langage. 8 e édition. Avec une intro aux design patterns et une annexe sur la norme C++11. Claude Delannoy

C++ Programmer. en langage. 8 e édition. Avec une intro aux design patterns et une annexe sur la norme C++11. Claude Delannoy Claude Delannoy Programmer en langage C++ 8 e édition Avec une intro aux design patterns et une annexe sur la norme C++11 Groupe Eyrolles, 1993-2011. Groupe Eyrolles, 2014, pour la nouvelle présentation,

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

Le prototype de la fonction main()

Le prototype de la fonction main() Le prototype de la fonction main() 1. Introduction...1 2. Paramètres et type de retour de la fonction main()...1 3. Exemple 1...2 4. La fonction exit() du C...2 5. Détecter le code de retour d un programme

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 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

Notions fondamentales du langage C# Version 1.0

Notions fondamentales du langage C# Version 1.0 Notions fondamentales du langage C# Version 1.0 Z 2 [Notions fondamentales du langage Csharp] [Date : 25/03/09] Sommaire 1 Tout ce qu il faut savoir pour bien commencer... 3 1.1 Qu est ce qu un langage

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

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

INF2015 Développement de logiciels dans un environnement Agile. Examen intra 20 février 2014 17:30 à 20:30

INF2015 Développement de logiciels dans un environnement Agile. Examen intra 20 février 2014 17:30 à 20:30 Examen intra 20 février 2014 17:30 à 20:30 Nom, prénom : Code permanent : Répondez directement sur le questionnaire. Question #1 5% Quelle influence peut avoir le typage dynamique sur la maintenabilité

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

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

Classe ClInfoCGI. Fonctions membres principales. Gestion des erreurs

Classe ClInfoCGI. Fonctions membres principales. Gestion des erreurs Utilisation des classes de PourCGI par Michel Michaud, version 2002-11-23 Les fichiers PourCGI.h et PourCGI.cpp rendent disponibles deux classes et une fonction libre qui permettent de faire facilement

Plus en détail

Chapitre 2. Classes et objets

Chapitre 2. Classes et objets Chapitre 2: Classes et Objets 1/10 Chapitre 2 Classes et objets Chapitre 2: Classes et Objets 2/10 Approche Orientée Objet Idée de base de A.O.O. repose sur l'observation de la façon dont nous procédons

Plus en détail

Avertissement : Ce cours suppose la connaissance et la maîtrise du langage C CONTENU DU COURS BIBLIOGRAPHIE

Avertissement : Ce cours suppose la connaissance et la maîtrise du langage C CONTENU DU COURS BIBLIOGRAPHIE Enseignement : GI 62 - C++ - Programmation orienté objet (C++) Objectif : Ce module se situe dans la continuité des modules (ii12) et UEL RAN Informatique et permet d'acquérir les bases de la modélisation

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

Introduction à la programmation orientée objet, illustrée par le langage C++ Patrick Cégielski cegielski@u-pec.fr

Introduction à la programmation orientée objet, illustrée par le langage C++ Patrick Cégielski cegielski@u-pec.fr Introduction à la programmation orientée objet, illustrée par le langage C++ Patrick Cégielski cegielski@u-pec.fr Mars 2002 Pour Irène et Marie Legal Notice Copyright c 2002 Patrick Cégielski Université

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

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 V. Recherche et tri

CHAPITRE V. Recherche et tri Cherchez et vous trouverez,... car qui cherche trouve. Matthieu 7 7-8 et Luc 11 9-10 CHAPITRE V Recherche et tri Objectif. Comprendre les techniques de base pour organiser des données ordonnées. Ce chapitre

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

et Programmation Objet

et Programmation Objet FACULTE POLYTECHNIQUE DE MONS Service d Informatique et Programmation Objet Mohammed Benjelloun 2 ème Bachelier Année académique 2008-2009 Table des matières Avant-propos--------------------------------------------------------------------------

Plus en détail

Éléments d informatique Cours 3 La programmation structurée en langage C L instruction de contrôle if

Éléments d informatique Cours 3 La programmation structurée en langage C L instruction de contrôle if Éléments d informatique Cours 3 La programmation structurée en langage C L instruction de contrôle if Pierre Boudes 28 septembre 2011 This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike

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

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

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

Le langage C++ (partie I)

Le langage C++ (partie I) Master Informatique des Organisations 1 ère et 2 ème années Spécialité ID/MIAGE-IF/MIAGE-SITN Le langage C++ (partie I) Maude Manouvrier Qu est ce que le C++? Rappels sur la gestion de la mémoire Premiers

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

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

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

30.avr.10 Présentation miniprojet. 9.mars.10 Cours 3 4.mai.10 Cours C++ 1. 16.mars.10 Cours 4 11.mai.10 Cours C++ 2

30.avr.10 Présentation miniprojet. 9.mars.10 Cours 3 4.mai.10 Cours C++ 1. 16.mars.10 Cours 4 11.mai.10 Cours C++ 2 2ème partie de cours: 23.fév.10 Cours 1 20.avr.10 TEST 24.fév.10 TP1 21.avr.10 miniprojet 26.fév.10 TP réserve 23.avr.10 miniprojet 2.mars.10 Cours 2 27.avr.10 Présentation miniprojet 3.mars.10 TP2 28.avr.10

Plus en détail

Module.NET 3 Les Assemblys.NET

Module.NET 3 Les Assemblys.NET Module.NET Chapitre 3 Les Assemblys.NET 2011/2012 Page 1 sur 13 Contenu Cours... 3 3.1 - Définition d un assembly.net... 3 3.2 - Private assembly ou assembly privé.... 3 3.3 - Shared assembly ou assembly

Plus en détail

Programmation en langage C

Programmation en langage C Programmation en langage C Anne CANTEAUT INRIA - projet CODES B.P. 105 78153 Le Chesnay Cedex Anne.Canteaut@inria.fr http://www-rocq.inria.fr/codes/anne.canteaut/cours C 2 Table des matières 3 Table des

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

INF111. Initiation à la programmation impérative en C http://ama.liglab.fr/ amini/cours/l1/inf111/ Massih-Reza Amini

INF111. Initiation à la programmation impérative en C http://ama.liglab.fr/ amini/cours/l1/inf111/ Massih-Reza Amini Initiation à la programmation impérative en C http://ama.liglab.fr/ amini/cours/l1// Massih-Reza Amini Université Joseph Fourier Laboratoire d Informatique de Grenoble 2/52 Introduction Structures de contrôle

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

Introduction à l algorithmique et à la programmation M1102 CM n 3

Introduction à l algorithmique et à la programmation M1102 CM n 3 Introduction à l algorithmique et à la programmation M1102 CM n 3 DUT Informatique 1 re année Eric REMY eric.remy@univ-amu.fr IUT d Aix-Marseille, site d Arles Version du 2 octobre 2013 E. Remy (IUT d

Plus en détail

Notes du cours 4M056 Programmation en C et C++ Vincent Lemaire et Damien Simon

Notes du cours 4M056 Programmation en C et C++ Vincent Lemaire et Damien Simon Notes du cours 4M056 Programmation en C et C++ Vincent Lemaire et Damien Simon 13 janvier 2015 2 Table des matières Organisation générale du cours 7 1 Notions générales d algorithmique et de programmation

Plus en détail

Seance 2: En respectant la méthode de programmation par contrat, implémentez les autres fonctions de jeu.

Seance 2: En respectant la méthode de programmation par contrat, implémentez les autres fonctions de jeu. Seance 2: Complétion du code de jeu. (durée max: 2h) Mot clé const et pointeurs: En respectant la méthode de programmation par contrat, implémentez les autres fonctions de jeu. Implémentez jeu_recupere_piece

Plus en détail

Langage Java. Classe de première SI

Langage Java. Classe de première SI Langage Java Table des matières 1. Premiers pas...2 1.1. Introduction...2 1.2. Mon premier programme...2 1.3. Les commentaires...2 2. Les variables et les opérateurs...2 3. La classe Scanner...3 4. Les

Plus en détail

Systeme d'exploitation

Systeme d'exploitation Introduction au dévellopement de Methodes Natives Partie I : appelle de methodes C++ sous windows Auteur: Frank Sauvage. 1 \ introduction aux methodes natives : Les methodes natives sont des methodes devellopées

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

Une introduction à Java

Une introduction à Java Une introduction à Java IFT 287 (Semaine 1) UNIVERSITÉ DE SHERBROOKE 1 Java - Historique Développé par Sun Microsystems en 1994 Inventeur James Gosling (canadien!) Objectif langage sûr (fortement typé)

Plus en détail

Programmation stochastique

Programmation stochastique Programmation stochastique (Partie 1) IFT-6512 Hiver 2008 Présentation succinte COIN-OR? COmputational INfrastructure for Operations Research. Préalablement, COIN-OR tenait pour Common Optimization INterface

Plus en détail

Le Langage C Version 1.2 c 2002 Florence HENRY Observatoire de Paris Université de Versailles florence.henry@obspm.fr

Le Langage C Version 1.2 c 2002 Florence HENRY Observatoire de Paris Université de Versailles florence.henry@obspm.fr Le Langage C Version 1.2 c 2002 Florence HENRY Observatoire de Paris Université de Versailles florence.henry@obspm.fr Table des matières 1 Les bases 3 2 Variables et constantes 5 3 Quelques fonctions indispensables

Plus en détail

Organigramme / Algorigramme Dossier élève 1 SI

Organigramme / Algorigramme Dossier élève 1 SI Organigramme / Algorigramme Dossier élève 1 SI CI 10, I11 ; CI 11, I10 C24 Algorithmique 8 février 2009 (13:47) 1. Introduction Un organigramme (ou algorigramme, lorsqu il est plus particulièrement appliqué

Plus en détail

OS Réseaux et Programmation Système - C5

OS Réseaux et Programmation Système - C5 OS Réseaux et Programmation Système - C5 Rabie Ben Atitallah rabie.benatitallah@univ-valenciennes.fr RPC - XDR Rappel RPC: Remote Procedure Call Besoin d un environnement de haut niveau pour le développement

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

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

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

C++ : PROGRAMMATION-OBJET

C++ : PROGRAMMATION-OBJET Cours d informatique 2003/2004 C++ : PROGRAMMATION-OBJET SOMMAIRE : Chapitre 1 : Le concept d objet........ 1 1.1 Objet usuel.............. 1 1.2 Objet informatique Classe........ 2 1.3 Encapsulation.............

Plus en détail

ETUDE DE CAS en UML : GESTION DES COMMANDES DE PIECES FABRIQUEES PAR LA SOCIETE C

ETUDE DE CAS en UML : GESTION DES COMMANDES DE PIECES FABRIQUEES PAR LA SOCIETE C ETUDE DE CAS en UML : GESTION DES COMMANDES DE PIECES FABRIQUEES PAR LA SOCIETE C La société C fabrique des pièces métalliques réalisées dans son atelier. La société C est en relation commerciale uniquement

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

Présentation du PL/SQL

Présentation du PL/SQL I Présentation du PL/ Copyright Oracle Corporation, 1998. All rights reserved. Objectifs du Cours A la fin de ce chapitre, vous saurez : Décrire l intéret du PL/ Décrire l utilisation du PL/ pour le développeur

Plus en détail

Cours Langage C/C++ Programmation modulaire

Cours Langage C/C++ Programmation modulaire Cours Langage C/C++ Programmation modulaire Thierry Vaira BTS IRIS Avignon tvaira@free.fr «v0.1 Rappel Programmation modulaire (1/2) Le découpage d'un programme en sous-programmes est appelée programmation

Plus en détail

Le langage C. Introduction, guide de reference

Le langage C. Introduction, guide de reference Le langage C Introduction, guide de reference Ce document est une présentation du langage de programmation C, de sa syntaxe et de ses spécificités. Il est destiné essentiellement à servir de mémo-guide

Plus en détail

avec des nombres entiers

avec des nombres entiers Calculer avec des nombres entiers Effectuez les calculs suivants.. + 9 + 9. Calculez. 9 9 Calculez le quotient et le rest. : : : : 0 :. : : 9 : : 9 0 : 0. 9 9 0 9. Calculez. 9 0 9. : : 0 : 9 : :. : : 0

Plus en détail

ASR1 TD7 : Un microprocesseur RISC 16 bits

ASR1 TD7 : Un microprocesseur RISC 16 bits {Â Ö Ñ º ØÖ Ý,È ØÖ ºÄÓ Ù,Æ ÓÐ ºÎ ÝÖ Ø¹ ÖÚ ÐÐÓÒ} Ò ¹ÐÝÓÒº Ö ØØÔ»»Ô Ö Óº Ò ¹ÐÝÓÒº Ö» Ö Ñ º ØÖ Ý»¼ Ö½» ASR1 TD7 : Un microprocesseur RISC 16 bits 13, 20 et 27 novembre 2006 Présentation générale On choisit

Plus en détail

4. Groupement d objets

4. Groupement d objets Conception objet en Java avec BlueJ une approche interactive 4. Groupement d objets Collections et itérateurs David J. Barnes, Michael Kölling version française: Patrice Moreaux Rédigé avec 1.0 Principaux

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

MICROINFORMATIQUE NOTE D APPLICATION 1 (REV. 2011) ARITHMETIQUE EN ASSEMBLEUR ET EN C

MICROINFORMATIQUE NOTE D APPLICATION 1 (REV. 2011) ARITHMETIQUE EN ASSEMBLEUR ET EN C Haute Ecole d Ingénierie et de Gestion Du Canton du Vaud MICROINFORMATIQUE NOTE D APPLICATION 1 (REV. 2011) ARITHMETIQUE EN ASSEMBLEUR ET EN C Programmation en mode simulation 1. DOCUMENTS DE RÉFÉRENCE...

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

IUT ANNECY Département Mesures Physiques Cours d informatique Initiation au langage C

IUT ANNECY Département Mesures Physiques Cours d informatique Initiation au langage C IUT ANNECY Département Mesures Physiques Cours d informatique Initiation au langage C myriam.chesneau@univsavoie.fr Mots clefs : Initiation à la programmation Langage C Variables Opérations Structures

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