Un petit pb de fonction en c++
Bonjour tout le monde et bonne année à tous avec plein de bonheur!!!!!
J'ai un problème avec les fonctions je ne comprend pas comment ça marche.
je doit faire un programme qui me compte les caractères d'un texte je vois bien comment je doit faire mais je ne sait pas comment je doit l'ecrire. J'arrive pas à appeler ma fonction.
SVP aidez moi
merci d'avance
J'ai un problème avec les fonctions je ne comprend pas comment ça marche.
je doit faire un programme qui me compte les caractères d'un texte je vois bien comment je doit faire mais je ne sait pas comment je doit l'ecrire. J'arrive pas à appeler ma fonction.
SVP aidez moi
merci d'avance
A voir également:
- Un petit pb de fonction en c++
- Fonction si et - Guide
- Petit 2 ✓ - Forum Bureautique
- Comment imprimer une photo en petit - Forum Photo numérique
- Trier du plus petit au plus grand excel - Guide
- Petit 3 ✓ - Forum Word
44 réponses
Bon, je sais pas si c'est une bonne chose que de te macher tout le travail ... Enfin, c'est simple : tu te positionnes à l'emplacement souhaité dans ta phrase et tu remontes jusqu'à trouver un espace que tu remplaces par un saut de ligne. Et tu recommences la même chose jusqu'à la fin de la phrase :
int deb, l; cout << "Entrer le nombre de caractere que vous voulez pour une ligne :" ; cin >> l; deb = 0; i = l; while (i < len) { while ((i>deb) && (text[i] != ' ')) i--; if (i>deb) { text[i]=10; deb = i; i += l; } } std::cout << "phrase découpé = " << std::endl << text << std::endl;
widi70
Messages postés
649
Date d'inscription
Statut
Membre
Dernière intervention
65
dit tu peut m'expliquer à quoi il sert le deb enfin ce qu'il represente
lirey83
Messages postés
75
Date d'inscription
Statut
Membre
Dernière intervention
13
deb représente l'indice du caractère qui sera au début de chaque (nouvelle) ligne. Au début il vaut 0 puis il vaudra i, c'est-à-dire là ou on à placer le retour à la ligne.
j'ai fait ça mais j'ai une erreur et je voit pas d'ou el vient?
#include <iostream>
#include <string>
using namespace std;
string texte;
int len;
cout << "Veuillez entrer votre texte." << endl;
cin >> texte;
cout << "Le nombre de caractères est:" << texte.size() << endl;
#include <iostream>
#include <string>
using namespace std;
string texte;
int len;
cout << "Veuillez entrer votre texte." << endl;
cin >> texte;
cout << "Le nombre de caractères est:" << texte.size() << endl;
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
ah ben enfaite j'ai trouver ce qui va pas voila le resultat:
*/Compter les caractères */
#include <iostream>
#include <string> */ bibliothèque pour la fonction len*/
using namespace std;
main {
string texte;
int len = texte.size();
cout << "Veuillez entrer votre texte." << endl;
cin >> texte;
cout << "Le nombre de caractères est:" << len << endl;
}
mais si qqn pourrai me donner un coup de main pour faire un programme qui calcul le nombre de mot se serait vraiment gentille
je ne sais vraiment pas comment faire
*/Compter les caractères */
#include <iostream>
#include <string> */ bibliothèque pour la fonction len*/
using namespace std;
main {
string texte;
int len = texte.size();
cout << "Veuillez entrer votre texte." << endl;
cin >> texte;
cout << "Le nombre de caractères est:" << len << endl;
}
mais si qqn pourrai me donner un coup de main pour faire un programme qui calcul le nombre de mot se serait vraiment gentille
je ne sais vraiment pas comment faire
ben enfaite mon programme il marche qu'a moitié
si j'ecrit Bonour tout le monde il va afficher 7 il compte que Bonjour.
Donc si qqn pourrait me donner une autre solution ou expliquer comment faire pour faire un programme avec des bouble (enfaite je ne voit pas quand je doit incrementer mon compteur)
merci d'avance
si j'ecrit Bonour tout le monde il va afficher 7 il compte que Bonjour.
Donc si qqn pourrait me donner une autre solution ou expliquer comment faire pour faire un programme avec des bouble (enfaite je ne voit pas quand je doit incrementer mon compteur)
merci d'avance
cin semble supprimer les espaces ... essayes comme ça :
int main() { char texte[50]; cout << "Veuillez entrer votre texte." << endl; cin.getline(texte,50); int len = strlen(texte); cout << "Le nombre de caractères est : " << len << endl; }
oui mais si le nombre de caractère est superieur à 50 ça marche plus si???,
et moi il fau que ça marche pour un nbr inconnu de caractere
et moi il fau que ça marche pour un nbr inconnu de caractere
Effectivement, si la chaine est supérieur à 50, on a un problème. Mais Google est ton ami, une simple recherche sur les mots cin, espace et c++ te conduit à la page suivante :
http://fr.wikibooks.org/wiki/Programmation_C++_(d%C3%A9butant)/La_classe_string
qui répond à la question, donc le code correct est :
http://fr.wikibooks.org/wiki/Programmation_C++_(d%C3%A9butant)/La_classe_string
qui répond à la question, donc le code correct est :
int main() { string texte; cout << "Veuillez entrer votre texte." << endl; getline(cin,texte); int len = texte.length(); cout << "Le nombre de caractères est : " << len << endl; }
Heu, je sais pas comment interpréter ton commentaire. Mais une chose est sure, ton code ne marche pas :
L'utilisation de "std::cin >> text;" pour récupérer une phrase complète ne marche pas (et donc la valeur que tu stockes dans len est fausse), il faut utiliser "getline(cin,text);"
cf le lien que j'ai donné plus haut.
L'utilisation de "std::cin >> text;" pour récupérer une phrase complète ne marche pas (et donc la valeur que tu stockes dans len est fausse), il faut utiliser "getline(cin,text);"
cf le lien que j'ai donné plus haut.
#include <iostream> #include <string> extern "C"{ #include <ctype.h> } int main(){ // Lecture std::string text; std::cout << "texte ?"; std::cin >> text; // Nombre de caracteres std::size_t len = text.length() std::cout << "nombre de caractères = " << len << std::endl; // Nombre de mots unsigned int nb_words=0; for(unsigned int i=0;i<len;++i){ // avancer jusqu'au prochain mot while(!isalpha(text[i] && i<len) ++i; // on a atteint la fin de la chaine if(i>=len) break; // on a atteint un nouveau mot // avancer jusqu'à la fin du mot ++nb_words; while(isalpha(text[i] && i<len) ++i; } std::cout << "nombre de mots = " << nb_words<< std::endl; return 0; }
Ou truc dans le genre... Là j'ai pas de compilateur sous la main...
Bonne chance
merci bcp tout le monde pour votre aide mamiemando tu pourrais m'expliquer ça sert à quoi :
extern "C"{
#include <ctype.h>
merci bcp
extern "C"{
#include <ctype.h>
merci bcp
En C++, quand tu inclues header "C" il faut rajouter ça autour car sinon ça peut déconner avec certains compilateurs.
Bonne chance
Bonne chance
ah gros probleme je n'ai pas le droit d'utiliser des fonctions toutes faites donc voila tout mon travail est foutu.
pour les caractere je fait comment, je ne sais pas quand je doit incrementé le compteur.
tant que car = toutes les lettres espaces etc, etc. Je peut ecrire ça comment????
et pour les mots je peu faire un truc comme ça:
#include <iostream>
using namespace std;
int main{
int nb-mots;
int mots;
char texte;
cout<<"votre texte"<<endl;
cin>>texte;
nb-mots=0;
mots=0;
while (mots!='/n'){
if mots = ' '{
nb-mots=nb-mots+1;
}
else
mot=mot+1;
}
cout<<"il y a "<<nb-mots<<"mots"<<endl;
}
mais ça ne marche pas donc si vous pouvez m'aidez
merci encore bcp de votre aide
pour les caractere je fait comment, je ne sais pas quand je doit incrementé le compteur.
tant que car = toutes les lettres espaces etc, etc. Je peut ecrire ça comment????
et pour les mots je peu faire un truc comme ça:
#include <iostream>
using namespace std;
int main{
int nb-mots;
int mots;
char texte;
cout<<"votre texte"<<endl;
cin>>texte;
nb-mots=0;
mots=0;
while (mots!='/n'){
if mots = ' '{
nb-mots=nb-mots+1;
}
else
mot=mot+1;
}
cout<<"il y a "<<nb-mots<<"mots"<<endl;
}
mais ça ne marche pas donc si vous pouvez m'aidez
merci encore bcp de votre aide
je corrige le code de mamiemando :
int main() { // Lecture std::string text; std::cout << "texte ?"; getline(cin,text); // Nombre de caracteres std::size_t len = text.length(); std::cout << "nombre de caractères = " << len << std::endl; // Nombre de mots unsigned int nb_words=0; for(unsigned int i=0;i<len;i++) { // avancer jusqu'au prochain mot while ((isalpha(text[i]) && i<len)) i++; // on a atteint la fin d'un mot ou de la chaine if (i<=len) nb_words++; } std::cout << "nombre de mots = " << nb_words<< std::endl; return 0; }
Crées toi tes propres fonctions :
bool my_isalpha(char lettre) { return (((lettre >= 'A') && (lettre <= 'Z')) || ((lettre >= 'a') && (lettre <= 'z'))); } int my_length(string phrase) { int i=0; while (phrase[i] != 0) i++; return i; }
ben c'est justement ce que font ses fonctions ! Si t'aime pas les fonctions intègres les directement dans le code de Mamiemando qui marche très bien !
et je met quand même
extern "C"{
#include <ctype.h>
car je voit pas comment l'expliquer clairement en un commentaire simple
extern "C"{
#include <ctype.h>
car je voit pas comment l'expliquer clairement en un commentaire simple
merci bcp de toute votre aide, le programme fonctionne correctement mais pour compter les mots si j'ecrit
bonjour tout le monde. ca va bien? il compte 8 il compte le ? comme un mot. Je doit modifier quoi dans le programme pour qu'il ne compte pas comme un mot le ? , ; : !
Et sinon je voudrait qu'a un nombre de caractere donné on reécrit le texte et à x caractere on met un retour à la ligne .
j'ai fait ça:
#include <iostream>
#include <string>
int main()
{
// Lecture
string text;
int l;
cout << "texte ?";
getline(cin,text);
cout<<"Entrer le nombre de caractere que vous voulez pour une ligne?<<endl;
cin>>l;
// Nombre de caracteres
size_t len = text.length();
cout << "nombre de caractères = " << len <<endl;
// Nombre de mots
unsigned int nb_words=0;
for(unsigned int i=0;i<len;i++)
{
// avancer jusqu'au prochain mot
while ((isalpha(text[i]) && i<len)) i++;
// on a atteint la fin d'un mot ou de la chaine
if (i<=len) nb_words++;
}
cout << "nombre de mots = " << nb_words<<endl;
return 0;
if (len>l){
cout<<len=0;len<l;len ++<<endl;
}
else
cout<<size_t len<<endl;
}
mais ça ne fonctionne pas si vous pouvez me donner un peit coup de main.
bonjour tout le monde. ca va bien? il compte 8 il compte le ? comme un mot. Je doit modifier quoi dans le programme pour qu'il ne compte pas comme un mot le ? , ; : !
Et sinon je voudrait qu'a un nombre de caractere donné on reécrit le texte et à x caractere on met un retour à la ligne .
j'ai fait ça:
#include <iostream>
#include <string>
int main()
{
// Lecture
string text;
int l;
cout << "texte ?";
getline(cin,text);
cout<<"Entrer le nombre de caractere que vous voulez pour une ligne?<<endl;
cin>>l;
// Nombre de caracteres
size_t len = text.length();
cout << "nombre de caractères = " << len <<endl;
// Nombre de mots
unsigned int nb_words=0;
for(unsigned int i=0;i<len;i++)
{
// avancer jusqu'au prochain mot
while ((isalpha(text[i]) && i<len)) i++;
// on a atteint la fin d'un mot ou de la chaine
if (i<=len) nb_words++;
}
cout << "nombre de mots = " << nb_words<<endl;
return 0;
if (len>l){
cout<<len=0;len<l;len ++<<endl;
}
else
cout<<size_t len<<endl;
}
mais ça ne fonctionne pas si vous pouvez me donner un peit coup de main.