La présentation est en train de télécharger. S'il vous plaît, attendez

La présentation est en train de télécharger. S'il vous plaît, attendez

8PRO100 Éléments de programmation Les chaînes de caractères.

Présentations similaires


Présentation au sujet: "8PRO100 Éléments de programmation Les chaînes de caractères."— Transcription de la présentation:

1 8PRO100 Éléments de programmation Les chaînes de caractères

2 Les caractères En informatique, les caractères sont très importants puisqu ils sont utilisés pour la communication personne-machine. Puisque les ordinateurs ne peuvent manipuler que des séquences de bits. les caractères doivent être encodés en binaire. Un des codes les plus utilisés est le code ASCII. Chaque caractère est encodé à l aide de 8 bits: ce qui donne 256 possibilités.

3 Code ASCII

4 Code ASCII étendu

5 Les constantes de type caractère En C une constante de type caractère est un nombre entier écrit sous la forme dun caractère entre apostrophes, comme a. La valeur dune constante de type caractère est égale à la valeur du caractère daprès le jeu de caractère de la machine (ex. ASCII). Exemples: a vaut 97 A vaut 65 B vaut 66 0 vaut 48

6 Les séquences déchappement \acaractère dalerte (sonnerie, bell) \bretour en arrière (backspace) \fsaut de page (formfeed) \nfin de ligne (newline) \rretour de chariot (carriage return) \ttabulation horizontale \vtabulation verticale \\backslash \?point dinterrogation \apostrophe \ guillemet \ooonombre octal \xhhnombre hexadécimale

7 Les constantes de type chaîne Un constante de type chaîne est une séquence de caractères, éventuellement vide, placée entre guillemets. Exemple: "Je suis une chaine " "Bonjour groupe!\n" Note: Les guillemets ne font pas partie de la chaîne. "\"Je suis one chaine\""

8 Les variables de type caractère Pour declarer une variable de type char, on procède de la façon suivante: char c1; /* c1 est une variable de type caractère */ char c2 = a;/* c2 est une variable de type caractère initialisée à a */

9 Les entrées et sorties #include /* fichier den-tête pour le C++ */ main(){ char c; cin >> c; cout << c; } #include /* fichier den-tête pour le C */ main(){ char c; c = getchar(); putchar(c); }

10 Les entrées et sorties int getchar(void) Retourne le caractère suivant (converti en un int). retourne EOF si la fin du fichier est atteinte ou si une erreur survient. int putchar(char c) Écrit le caractère c. Retourne le caractère écrit ou bien EOF en cas derreur. Le fichier den-tête stdio.h: Contient la déclaration des fonctions standards dentrée et de sortie (en C) Contient aussi la définition de EOF (End of file).

11 Exemple 1: Copier des fichiers #include /* copie lentrée sur la sortie, première version */ main(){ int c; c = getchar(); while (c != EOF) { putchar(c); c = getchar(); }

12 Exemple 1: Copier des fichiers #include /* copie lentrée sur la sortie; première version*/ main(){ int c; c = getchar(); while (c != EOF) { putchar(c); c = getchar(); } Pourquoi un int?

13 Qu'est-ce que EOF? Supposons que le fichier contienne trois entiers :

14 Qu'est-ce que EOF? Supposons que le fichier contienne trois entiers :

15 Qu'est-ce que EOF? Supposons que le fichier contienne trois entiers :

16 Qu'est-ce que EOF? Supposons que le fichier contienne trois entiers :

17 Exemple 1: Copier des fichiers La valeur retourné par getchar() peut être un des 256 caractères ASCII OU la valeur EOF La fonction getchar() peut donc retourner 257 valeurs possibles. Mais un char est un entier de 8 bits et ne peut donc représenter que 256 valeurs possibles. On doit donc utiliser plus de bits (et donc un int) pour faire la différence entre un caractère et EOF.

18 Exemple 1: Copier des fichiers Exemple: Sur SUNENS un int est un entier de 32 bits et EOF sécrit en binaire de la façon suivante: bits Losrque lon met EOF dans une variable de type char on ne met que les 8 premiers bits, cest-à-dire = 255 Le caractère dont la valeur est 255 est: ÿ

19 Exemple 1: Copier des fichiers #include /* copie lentrée sur la sortie, seconde version */ main(){ int c; while ((c=getchar()) != EOF) putchar(c); }

20 Exemple 2: Compter les caractères #include /* La fonction nbcar compte les caractères en entrée */ int nbcar(){ int nc; nc = 0; while (getchar() != EOF) nc = nc + 1; return nc; }

21 Exemple 3: Compter les lignes #include /* La fonction nblignes compte les lignes en entrée */ int nblignes(){ int c, nl; nl = 0; while ((c=getchar()) != EOF) if (c == \n) /* En fait on compte les nombre de */ nl = nl + 1; /* changement de lignes */ return nl; }

22 Exemple 4: Compter les mots #include #define DEDANS 1 /* à lintérieur dun mot */ #define DEHORS 0 /* à lextérieur dun mot */ /* La fonction nbmots compte les mots en entrée */ int nbmots(){ int c, nm, etat; nm = 0; etat = DEHORS; while ( (c=getchar()) != EOF ) if ( (c == \n) || (c == ) || (c == \t) ) etat = DEHORS; else if (etat == DEHORS) { etat = DEDANS; nm = nm + 1; } return nl; }

23 ctype.h Le fichier den-tête ctype.h contient la déclaration de fonctions destinées à tester les caractères: isdigit(char c) retourne 1 si c est un chiffre, 0 sinon is lower(char c) retourne 1 si c est une lettre minuscule, 0 sinon isupper(char c) retourne 1 si c est une lettre majuscule, 0 sinon isalpha(char c) retourne 1 si c est une lettre, o sinon isspace(char c) retourne 1 si c est un character d'espacement, 0 sinon et plusieurs autres.

24 Exemple 5: isdigit(c) #include int isdigit(char c){ return ( (c >= 0) && (c <=9) ); }

25 Exemple 6: islower(c) #include int islower(char c){ return ( (c >= a) && (c <=z) ); }

26 Exemple 7: isupper(c) #include int isupper(char c){ return ( (c >= A) && (c <=Z) ); }

27 Exemple 8: isalpha(c) #include int isalpha(char c){ return ( islower(c) || isupper(c)); }

28 Remarques Les exemples 5 à 8 pourraient ne pas fonctionner correctement sur un système utilisant un code autre que ASCII Dans ctype.h, ces fonctions prennent un int comme paramètre.

29 Les chaînes de caractères En C il ny a pas de variable de type chaîne de caractères. Une chaîne de caractère est un tableau de caractères se terminant par le caractère \0 (le caractère nul ayant la valeur 0) Ainsi la chaîne Bonjour groupe! serait représentée de la façon suivante: Bornjuogr oupe!\

30 Exemple 9: Lire une ligne #include /* lireligne: lit une ligne, la met dans s et retourne sa longueur qui doit être au plus lim-1 */ int lireligne( char s[], int lim) { int c, i; for (i=0; i< lim-1 && (c=getchar())!=EOF && c!= \n; i=i+1) s[i] = c; if (c==\n) { s[i]=c; i = i + 1; } return i; }

31 Exemple 10: Copier une chaîne #include /* copier: copie le tableau de dans le tableau vers ; on supose que le tableau vers est assez long */ void copie( char de[], char vers[]) { int i; i = 0; while ( (vers[i] = de[i]) != \0) i = i + 1; }

32 Exemple 11: Comparer 2 chaînes #include /* compare: Retourne -1, 0, ou 1 selon que chaine1 est lexicographiquement plus petite, égale ou plus grande que chaine2. void compare( char chaine1[], char chaine2[]) { int i; i = differe_ou(chaine1, chaine2);/* differe_ou retourne la première position où chaine1 et chaîne2 diffèrent. */ if ( chaine1[i] < chaine2[i] ) return -1; else if ( chaine1[i] > chaine2[i] ) return 1; else return 0; }

33 Exemple 11: Comparer 2 chaînes #include /* differe_ou: Retourne la première position où chaine1 et chaîne2 diffèrent. Retourne la position du caractère \0 si les deux chaînes sont égales. */ int differe_ou( char chaine1[], char chaine2[]) { int i; i = 0; while ( chaine1[i] != \0 && chaine1[i] = =chaine2[i]) i = i + 1; return i; }

34 Exemple 12: Initialiser une chaîne #include char mot1[80]="bonjour"; char mot2[80]={'b', 'o', 'n', 'j', 'o', 'u', 'r', '\0'}; for (i=0; mot1[i]; i++) putchar(mot1[i]); for (i=0; mot2[i]; putchar(mot2[i++]));

35 string.h Le fichier den-tête string.h contient des déclarations de fonctions permettant de manipuler des chaînes de caractères. char* strcpy(char[], char[]) copie la première chaine dans la seconde char* strcat (char[], char[]) concatène les deux chaînes int strcmpr (char[], char[]) compare deux chaînes int strlen(char[]) retourne la longueur dune chaîne et beaucoup dautres.

36 Exemple 13: chercher un mot #include char mot1[80]="bonjour"; char mot2[80]={'b', 'o', 'n', 'j', 'o', 'u', 'r', '\0'}; for (i=0; mot1[i]; i++) putchar(mot1[i]); for (i=0; mot2[i]; putchar(mot2[i++]));


Télécharger ppt "8PRO100 Éléments de programmation Les chaînes de caractères."

Présentations similaires


Annonces Google