GPA777 (Codage C++) 2
|
|
- Paulette Aubé
- il y a 6 ans
- Total affichages :
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étailINITIATION 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étailCours 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étailTD 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étailI. 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étailINFO-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étailProgramme 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étailInfo0101 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étail1/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étailLe 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étailCours 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étailClaude 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étailIntroduction à 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étailBases 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étailAlgorithmique 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étailCours 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étailIntroduction 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étailPlan 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étailPremiers 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étailRAPPELS 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étailCours 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étailQuelques é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étailIntroduction à 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étailCours 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étailC++ 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étailIntroduction à 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étail03/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étailInitiation à 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étailLE 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étailINTRODUCTION 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étailProgrammation 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étailProgrammation 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étailTP 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étailTP1 : 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étailDé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étailINTRODUCTION 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étailProgrammer 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étailC++ 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étailPré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étailLe 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étailJava 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étailLes 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étailNotions 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étailIntroduction à 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étailPour 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étailINF2015 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étailUEO11 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étailLicence 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étailClasse 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étailChapitre 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étailAvertissement : 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étailLes 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étailIntroduction à 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étailCorrigé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étailAlgorithmique 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étailCHAPITRE 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étailExceptions. 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étailet 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 Pierre Boudes 28 septembre 2011 This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike
Plus en détailStructure 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étail1. 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étailCours 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étailLe 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étailCours 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étailObjets 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étailCompression 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étail30.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étailModule.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étailProgrammation 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étailInitiation à 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étailINF111. 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étailPlan 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étailIntroduction à 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étailNotes 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étailSeance 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étailLangage 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étailSysteme 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étailChapitre 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étailUne 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étailProgrammation 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étailLe 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étailOrganigramme / 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étailOS 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étailProgrammation 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étailConventions 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étailUtilisation 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étailC++ : 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étailETUDE 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étailEPREUVE 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étailPré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étailCours 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étailLe 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étailavec 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étailASR1 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étail4. 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étailChapitre 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étailMICROINFORMATIQUE 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étailCours 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étailIUT 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étailIN 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