IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C++ Discussion :

Convertisseur decimal vers hexadecimal et inversement


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2017
    Messages : 4
    Par défaut Convertisseur decimal vers hexadecimal et inversement
    Bonjour à tous! Je ne sais pas si il fallait se présenter sur un topic en particulier mais je me lance depuis peu dans la prog et patauge un peu d'ailleurs...
    Je suis en train de faire un exercice qui consiste à faire un convertisseur decimal vers hexadecimal et vice verca.... le premier semble fonctionné mais je rencontre un probleme en compilant avec la partie hexadecimal vers décimal... voila bien 5h que je suis dessus....

    A la ligne 47 de mon code, code blocks me signal un probleme : error: no match for "operator !=" (operand types are 'std::string)... Quelqu'un pourrait il me venir en aide s'il vous plait... merci beaucoup.
    Ci dessous mon programme:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    #include <iostream>
     
    using namespace std;
     
    int main()
    {
        int entier, power, position ;
        char tabHexa[] = {"0123456789ABCDEF"} , option = 'w';
        string hexa, i;
     
        while ((option != 'Q' && option != 'q')) {
     
                cout << "Convertir un décimal en hexadecimal...................1";
                cout << "Convertir un hexadecimal en decimal...................2";
                cout << "Pour quitter..........................................q";
     
                if (option == '1'){
     
                    cout << " Entrez un entier =";
                    cin >> entier ;
     
                    hexa= "";
     
                        while (entier >= 0) {
                            if (entier < 16){
                                hexa= hexa + tabHexa[entier] ;
                                entier = -1 ;
                            } else {
                                hexa= hexa + tabHexa[entier/16] ;
                                entier = (entier%16) ;
                            }
                        }
     
            cout << "En hexadecimal, cela fait = " + hexa ;
                } else {
                    if (option == '2') {
     
                        cout<< "Entrez votre hexadecimal = " ;
                        cin >> hexa ;
     
                        power = 0;
                        entier=0;
     
                        while (hexa.size() > 0) {
                            i = hexa.substr((hexa.size())-1,1) ;
                            position = 0 ;
                            while (i != tabHexa[position]){
                                position = position + 1
                            }
                            entier = entier + position * 16^power ;
                            hexa = hexa.substr(0,(hexa.size())-1);
                            power = power + 1 ;
                        }
     
                        cout << "le resultat en decimal est = " + nombre ;
                    }
     
                }
        }
        return 0 ;
    }

  2. #2
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Par défaut
    Hello, je n'ai pas lu tout le code, juste la première ligne, donc il peut y avoir d'autres erreurs, mais error: no match for "operator !=" (operand types are 'std::string) signifie qu'il ne sait pas calculer si deux strings sont différentes. Or quand on regarde le début de ton fichier, il n'y a aucun #include <string> pour lui indiquer à quoi correspond string, et les opérations qu'on peut faire avec. Ajoute le, ça ira mieux.

    Tu te serait peut-être attendu à une erreur du genre : Je ne connais pas std::string. Le problème est que d'avoir #include<iostream> suffit pour avoir des bouts de <string>, car les deux sont entremêlés. Mais pas la totalité.

    [Edit] Astraya a tout à fait raison ! Il faut faire les deux modifications pour corriger ton code. Pour récupérer le ième caractère d'une chaîne s, il suffit de faire s[i], pas besoin de t'embêter avec substr.
    Ma session aux Microsoft TechDays 2013 : Développer en natif avec C++11.
    Celle des Microsoft TechDays 2014 : Bonnes pratiques pour apprivoiser le C++11 avec Visual C++
    Et celle des Microsoft TechDays 2015 : Visual C++ 2015 : voyage à la découverte d'un nouveau monde
    Je donne des formations au C++ en entreprise, n'hésitez pas à me contacter.

  3. #3
    Membre Expert Avatar de Astraya
    Homme Profil pro
    Consommateur de café
    Inscrit en
    Mai 2007
    Messages
    1 048
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Consommateur de café
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2007
    Messages : 1 048
    Par défaut
    Bonjour !
    Ce que te dis ton compilateur c'est qu'il n'existe pas pour la classe std::string un operateur de comparaison ! = avec un char.
    Ici ton i est un string et ton tableau est un char.
    Je t'invite a regarder la documentation de std::string une methode qui te permette de comparer un std::string avec un char.

    Peut être en recuperant un char de ton i ? Oufaire de ton char un string ? Ou tout autre moyen...
    A toi de voir

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Network game programmer
    Inscrit en
    Juin 2010
    Messages
    7 147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Canada

    Informations professionnelles :
    Activité : Network game programmer

    Informations forums :
    Inscription : Juin 2010
    Messages : 7 147
    Billets dans le blog
    4
    Par défaut
    Btw, tabHexa devrait être const, et surtout ^ n'est pas l'opérateur puissance.
    Pensez à consulter la FAQ ou les cours et tutoriels de la section C++.
    Un peu de programmation réseau ?
    Aucune aide via MP ne sera dispensée. Merci d'utiliser les forums prévus à cet effet.

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2017
    Messages : 4
    Par défaut
    Merci à tous pour ces réponses !!! Alors j'ai changé quelques bouts de code, j'ai ajouter le #include <string> et pour plus de sureté ,j'ai déclaré mon tabHexa en string et non plus en char... compilation du code...roulement de tambour....c'est bon! ca passe!Après pour l'opérateur puissance, j'ai ajouté un #include <math.h> et a corrigé ma puissance par pow(16,power)...
    Le nouveau probleme est que...apres compilation, le prog ne se lance pas mais la console m'affiche une suite interrompu de symbole en tout genre à trés grande vitesse....comme si j'avais à faire à une boucle infini...

  6. #6
    Membre éprouvé
    Homme Profil pro
    Inscrit en
    Octobre 2013
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2013
    Messages : 72
    Par défaut
    Bonjour
    Puisque tu commence à programmer en C++ il va falloir utiliser un débogueur. Au début c'est un peu difficile mais c'est absolument indispensable.
    Je te laisse googoliser "debogueur code blocks"...

  7. #7
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Salut,

    Juste un petit détail d'ordre "conceptuel" en passant...

    Il existe un principe essentiel en programmation connu sous l'abréviation de SRP (pour Single Responsability Principle ou, si tu préfères en francais, principe de la responsabilité unique). Ce principe nous dit que chaque type de donnée, chaque variable, chaque fonction ne devrait s'occuper que d'une seule et unique chose; que c'est la seule manière de pouvoir garantir (entre autres, grâce à des tests unitaires) qu'elle s'en occupe correctement.

    Or, ta fonction main s'occupe de
    1. servir de "point d'entrée" à ton programme (c'est ce que l'on attend de sa part)
    2. affichler le menu de ce que l'utilisateur peut choisir de faire (décimal -> hexadécimal / hexadécimal -> décimal / quitter)
    3. demander à l'utilisateur ce qu'il veut faire (!!! sans prendre en compte qu'il risque d'introduire n'importe quoi, comme 'a' ou comme "salut"!!!)
    4. demander à l'utilisateur d'introduire la valeur (décimale) à convertir (!!! sans prendre la peine de s'assurer que l'utilisateur n'introduit pas une connerie du genre "hello world" !!!)
    5. demander à l'utilisateur d'introduire une valeur (hexadécimale) à convertir (!!! sans prendre la peine de s'assurer que l'utilisateur n'introduit pas une connerie du genre "hello world" !!!)
    6. convertir une valeur décimale en hexadécimal
    7. convertir une valeur hexadécimale en décimal
    8. (afficher le résultat)
    Si mon compte est bon (et je peux t'assurer qu'il l'est), cela correspond à ... huit responsabilités différentes. Ce qui en fait donc sept de trop...

    L'idéal serait donc de subdiviser ce code -- aussi simple puisse-t-il être -- en différentes fonctions qui ne s'occuperait que d'une seule et unique chose, à savoir
    1. une fonction menu() qui affiche le menu de ce que l'utilisateur peut choisir de faire (et uniquement cela)
    2. une foncton choice() qui demande à l'utilisateur ce qu'il veut faire (et qui s'assure que la réponse soit cohérente avec ce que l'on attend de la part de l'utilisateur)
    3. une foncton getDecimal() qui s'occupe de l'introduction par l'utilisateur d'une valeur décimale (et qui s'assure de la cohérence de cette introduction)
    4. une fonction getHexa() qui s'occupe de l'introduction par l'utilisateur d'une valeur hexadécimale (et qui s'assure de la cohérence de cette introduction)
    5. une fonction hexaToDecimal() qui s'occupe d'effectuer la conversion d'une valeur hexadécimale en valeur décimale
    6. une fonction decimalToHexa() qui s'occupe d'effectuer la conversion d'une valeur décimale en valeur hexadécimale
    7. une fonction result() qui affiche le résultat
    8. la fonction main() qui s'occupe de mettre tout cela "en musique"

    En séparant les différentes responsabilité de la sorte, il te deviendra possible de tester chaque "fonctionnalité" de manière totalement indépendante, même si certaines (comme l'affichage du menu ou du résultat) n'en ont sans doute pas vraiment besoin .

    PS : Il n'y a que le nom des différentes fonctions auxquelles j'ai pensé... Ce sera à toi de déterminer si certaines d'entre-elles doivent prendre des paramètres, de quel type, ainsi que le type de valeur qu'elles devront renvoyer
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. convertir decimal a hexadecimal
    Par Micheal1221 dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 05/08/2006, 15h12
  2. Problème de conversion decimal vers Hexa
    Par Elbarto dans le forum C++
    Réponses: 1
    Dernier message: 06/02/2006, 19h37
  3. code c pour sockets (udp vers tcp et inversement)
    Par HiT dans le forum Développement
    Réponses: 11
    Dernier message: 19/11/2005, 18h03
  4. Probleme convertisseur RS232 vers RS485
    Par nico_ioltech dans le forum Composants
    Réponses: 2
    Dernier message: 05/10/2005, 09h10
  5. [langage] conversion décimal vers hexa
    Par chipster dans le forum Langage
    Réponses: 2
    Dernier message: 23/02/2004, 16h05

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo