Accueil > Forum > > > > char*
char*
jeudi 23 décembre 2004 à 01:18:02 |
char*

kollibar
|
je debute en C et donc je vais poser une question con... avec une chaine de caractère CHAR* comment je peut faire pour récupérer une sous chaine allant du caractère x(!=0) au caractère y?? j'ai un bouquin qui date de longtemps mais j'ai pas trouvé! merci KOLLIBAR bare
|
|
jeudi 23 décembre 2004 à 07:00:14 |
Re : char*

Nashua
|
Réponse acceptée !
en premier tu doit savoir qu'un char * est un pointeur sur chaine de char. il est donc preferable de noter char [n] qui est un string de n char.
dans ta question on va creer un pointeur sur char * puis on le deplace dans le string d 'x' position on va enfin lire le string jusque y en avancant le ptr.
exemple :
char string ={a,b,c,d,e,f,g}; char *ptr; int x = 2, y = 6; ptr = string; // ou tu peux mettre ptr = &string[0] qui est plus explicite
if ( x < strlen (string) ) // testons que x est < a la longueur de string ptr = ptr + x; if ( y < strlen (string)) { // meme chose pour y while (ptr < string + y ) { // je recupere le contenu de ptr (*ptr) ptr ++ ; // incrementons ptr }
Yves
|
|
jeudi 23 décembre 2004 à 09:04:09 |
Re : char*

ymca2003
|
Réponse acceptée !
char string ={a,b,c,d,e,f,g}; => faux
char string[] ={'a','b','c','d','e','f','g',0}; ou char string[] ="abcdefg";
|
|
jeudi 23 décembre 2004 à 11:27:32 |
Re : char*

Nashua
|
Merci ymca pour cette correction j'ai laisse passe cela, je devais etre mal reveille.. Yves
|
|
vendredi 24 décembre 2004 à 20:55:03 |
Re : char*

pmbala
|
Bonsoir à ts et joyeux noel!!! Voilà j'ai un petit pb en c++ sur les arbres, il s'agit de creer un arbre qui contient plusieurs champs de type differents ds chaque noeud...Je sais le faire pr un arbre qui contient seulement un caractere ou un entier,je vous donne une partie de mon code...
/*je declares des struct pr chaque champ */ #include<iostream> using namespace std; struct DATE { int jj,mm,aa; // jour mois année }; struct ADRESSE{ int Num_piste; //numero de piste oqp par file... int Num_Sect; // ...... - .... secteur... }; struct Noeud{ char * Nom_file,*Type_file; ADRESSE * Adr; DATE * date; Noeud *gauche,*droite,*pere ; //sous arbres gauche et droit... }; class Repertoire{ public: Noeud * Racine; void CreerFile( ); Noeud * InsererFile(char *nom,Noeud* courant); ..... }; void repertoire::CreerFile() { char reponse,*nom; Racine=new(Noeud); Racine->gauche=Racine->droite->Racine->pere=Null; courant->Nom_file= "toto" ???? /* là je bloque,parce que j'ai +sieurs champs,je me demande si pr le premier noeud il faut initialiser directemt tous les champs,du genre: Racine->X= "Y"; /*
Avec un arbre dont le noeud comprend un seul champ,j'aurais fais simplement Racine->X=element pr stocker element dans X; J'espère que vs allez comprendr de koi je parle et que vs allez m'aider le + tôt possible,merci...
|
|
vendredi 24 décembre 2004 à 20:55:55 |
char * avec arbres binaires...

pmbala
|
Bonsoir à ts et joyeux noel!!! Voilà j'ai un petit pb en c++ sur les arbres, il s'agit de creer un arbre qui contient plusieurs champs de type differents ds chaque noeud...Je sais le faire pr un arbre qui contient seulement un caractere ou un entier,je vous donne une partie de mon code...
/*je declares des struct pr chaque champ */ #include<iostream> using namespace std; struct DATE { int jj,mm,aa; // jour mois année }; struct ADRESSE{ int Num_piste; //numero de piste oqp par file... int Num_Sect; // ...... - .... secteur... }; struct Noeud{ char * Nom_file,*Type_file; ADRESSE * Adr; DATE * date; Noeud *gauche,*droite,*pere ; //sous arbres gauche et droit... }; class Repertoire{ public: Noeud * Racine; void CreerFile( ); Noeud * InsererFile(char *nom,Noeud* courant); ..... }; void repertoire::CreerFile() { char reponse,*nom; Racine=new(Noeud); Racine->gauche=Racine->droite->Racine->pere=Null; courant->Nom_file= "toto" ???? /* là je bloque,parce que j'ai +sieurs champs,je me demande si pr le premier noeud il faut initialiser directemt tous les champs,du genre: Racine->X= "Y"; /*
Avec un arbre dont le noeud comprend un seul champ,j'aurais fais simplement Racine->X=element pr stocker element dans X; J'espère que vs allez comprendr de koi je parle et que vs allez m'aider le + tôt possible,merci...
|
|
lundi 27 décembre 2004 à 09:08:10 |
Re : char*

ymca2003
|
courant->Nom_file= "toto" ???? non
il faut soit déclarer un tableau de char soit allouer le tableau avec malloc et y recopier la chaîne avec strcpy.
struct Noeud{ char Nom_file[256],Type_file[256]; ADRESSE * Adr; DATE * date; Noeud *gauche,*droite,*pere ; //sous arbres gauche et droit... };
strcpy(puis courant->Nom_File, "toto");
|
|
lundi 27 décembre 2004 à 11:09:27 |
Re : char*

pmbala
|
Merci pr ta reponse,je vais essayer tt à l'heure! je suppose que tu veux parler de new pr allouer la memoire,car je suis en c++,mais dis moi pr stocker les autres infos dans le noeud est ce que je vais à chaque fois utiliser strcpy(...)? J'ai pensé à creer une fction Arbre * Saisi_Info() qui fait ce travail pr ttes les variables et puis je ne fais que l'appeler ds InsererFile(... ),merci encore pr ta reponse...
|
|
lundi 27 décembre 2004 à 11:20:15 |
Re : char*

ymca2003
|
strcpy est à utiliser pour toutes les chaînes de caractères, pour les autres, c'est une affectation directes. Met directement des structure ADRESSE et DATE dans le noeud plutôt que des pointeurs (cela évitera de faire des allocations multiples d'un noaud, puis des chaînes, puis des sous-structure => faire directement une allocation globales du noeud) :
struct Noeud{ char Nom_file[256]; char Type_file[256]; ADRESSE Adr; DATE date; Noeud *gauche,*droite,*pere ; //sous arbres gauche et droit... };
pour créer et initialisaer un nouveau noeud : Noeud* Creer() { Noeud* n = new Noeud; strcpy(n->Nom_file, "nom fich"); strcpy(n->Type_file, 'Type fich"); n->Adr.Num_piste = 1234; n->Adr.Num_Sect = 4567; n->date.jj = 27; n->date.mm = 12; n->date.aa = 2004;
n->gauche = NULL; n->droite = NULL; n->pere = NULL; return n; }
|
|
lundi 27 décembre 2004 à 11:20:48 |
Re : char*

pmbala
|
ah oui,tu parle d'allouer de l'espace pr le tableau,alors si je cmprend bien pr chaque type de variable j'aurai un tableau à allouer du genre:
pr les adresses: courant->ADRESSE=new(Tab_Adr); courant->ADRESSE->Num_Piste=num_1; courant->ADRESSE->Num_Sect=num_2; Pr les DATE: courant->DATE=new(Tab_Date); courant->DATE->jj=...
Je vais egalement essayer ça,de tte les façon ça me donne des idées rien que le fait d'avoir lu ça!
|
|
Cette discussion est classée dans : caractère, chaine, char, green, blue
Répondre à ce message
Sujets en rapport avec ce message
manipulation desformules logiques : URGENT [ par The_Legacy ]
Bonjour, je suis en train de développer un petit programme qui permet d'évaluer des expression logiques telles que ((a et b) ou (c et (non d))).A part
pbme avec chaine de caractère et sscanf (débutant :( ) [ par peyou ]
sur une chaine de caractère de la forme "bidule = machin", je voudrais extraire les deux chaines "bidules" et " machin"1/ le nombre d'espace autour du
aarg Chaine de caractère [ par NeoUmbrella ]
Voila j'ai une question tres bete mais je ne comprends pas:char mot1[] = "test";char mot2[] = "test";Pourquoi qand je test avec un if mot1 n'est pas e
transformer un int en chaine de caractère [ par lenneth666 ]
Voila j'ai comme code ceci char *tmp2=(char *)malloc(5000); int res = 15; je voudrais savoir comment mettre res dans tmp2 le cast ne marche pas, et
Ajouter deux chaines de caractère. [ par Fituza ]
Bonjour,j'aimerai savoir comment ajouter une chaine de caractère de type char* avec une autre chaine de type const char*;exemple: char* access = "Rsc
tableau de chaine de caractère [ par delaktn ]
salut, Je réalise une application dont je besoin d'un tableau de chaine de caractère et voila la déclaration de ce tableau: char* t[10]; j'ai réalisé
RS232 ou RS485 dial entre 2 pics [ par Pat2903 ]
Bonjour je suis en projet pour crée un dialogue RS485 entre deux pics. Mon souci c'est que j'utilise MPLAB et le Compilateur C18. j'utilise la library
lire une chaine de caractère caractère par caractère avec c++builder 6 [ par dl6 ]
bon j'expose mon problème je dois lire des coordonnées de fabrication en norme iso qui sont stocké dans un fichier. je voudrai pourvoir les lire carac
suppression caractère [ par fadiam ]
bonsoir. une fonction lisant une chaine de caractères n'accepte que les caractères entre '0' et '9' (chiffres) et les ',' '-' '.' et ' '. Si il y a d
Convertion d'entiers/flottant vers un char* [ par katerson ]
Bonjour! Dans le cadre d'un échange de données serveur/client, j'ai besoin de convertir plusieurs int dans un char* afin d'envoyer la chaine via prot
Livres en rapport
|
Derniers Blogs
SESSION SILVERLIGHT 5 3D : SLIDES ET DEMOSSESSION SILVERLIGHT 5 3D : SLIDES ET DEMOS par Groc
Durant les techdays, j'ai eu le plaisir d'animer une session sur Silverlight 5 et la 3D avec Simon Ferquel. Comme promis, voici nos slides et mes démos (celles avec le viper BSG) ici et là. Pour mémoire, les démos utilisent toutes le viper BSG...
Cliquez pour lire la suite de l'article par Groc [TECHDAYS 2012] SESSION WEBMATRIX 2 : LE COUTEAU SUISSE GRATUIT POUR VOS DéVELOPPEMENTS WEB - SLIDES[TECHDAYS 2012] SESSION WEBMATRIX 2 : LE COUTEAU SUISSE GRATUIT POUR VOS DéVELOPPEMENTS WEB - SLIDES par gpommier
Suite à la session que j'ai présenté sur WebMatrix 2, vous pouvez trouver les slides ici, ainsi que les démos en packages nuget : démos1 et démos2 J'en profite pour remercier chaleureusement tous ceux qui sont venus très nombreux à cette sess...
Cliquez pour lire la suite de l'article par gpommier [SHAREPOINT] LES SESSIONS TECHDAYS 2012.[SHAREPOINT] LES SESSIONS TECHDAYS 2012. par Patrick Guimonet
Voici donc pour ceux qui n'ont pas pu venir, ou ceux qui n'ont pas pu toutes les suivre la liste des sessions SharePoint aux TechDays 2012, que je mettrais à jour dès que les liens des vidéo seront disponibles. Ou ici : http...
Cliquez pour lire la suite de l'article par Patrick Guimonet TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3 par ROMELARD Fabrice
Speaker: Bernard Ourghanlian Cette session est comme chaque jour transmise en live par BrainSonic, et j'ai donc suivi cette troisième pleinière par ce moyen sur mon iPad . Elle est dédiée comme chaque année à la mise en perspective de l'é...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE !MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE ! par Vko
Hier durant une session dédiée aux Techdays 2012, j'ai eu le plaisir d'annoncer la sortie de la Béta 2 de Mishra Reader. C'est quoi ? Pour les utilisateurs, c'est une vraie expérience de lecture de flux RSS sur Windows. Rien à voir avec les produit...
Cliquez pour lire la suite de l'article par Vko
Forum
ALGORITHMESALGORITHMES par whayoub
Cliquez pour lire la suite par whayoub
Logiciels
PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V8.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V8.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|