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 :

décalage de bits


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Octobre 2007
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 16
    Par défaut décalage de bits
    bonjour j'ai un petit probleme voila l'énoncé :

    Décoder une valeur binaire (8bits) passé en argument sous forme de chaine de caractères, en valeur entiere!!

    mais ce que j'ai fais ne marche pas pouvez vous me corrigé ??
    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
     
    main()
    {
      int i,val,result;
      char cbin[9];
     
      printf("rentrez valeur : ");
      scanf("%s",cbin);
      for(i=0;i<8;i++)
      {
                      result=val&(1<<i);
                      if(result==0)
                      cbin[7-i]=48;
                      else
                      cbin[7-i]=49;
      }
      cbin[8]=0;
      printf("la nouvelle valeur est : %.1d \n",cbin);
      system("PAUSE");	
      return 0;
    }

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 67
    Par défaut
    deja petit souci dans scanf()

    les fonctions en C passes les copies donc typiquement

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    scanf("%s",&cbin);

  3. #3
    Membre averti
    Inscrit en
    Octobre 2007
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 16
    Par défaut
    vu que c'est un tableau on m'a dit qu'il fallait pas le ====>&

  4. #4
    Rédacteur
    Avatar de Franck.H
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2004
    Messages
    6 951
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Service public

    Informations forums :
    Inscription : Janvier 2004
    Messages : 6 951
    Par défaut
    Citation Envoyé par darkewne Voir le message
    vu que c'est un tableau on m'a dit qu'il fallait pas le ====>&
    Dans le cas d'une variable tu le passes mais dans le cas d'un tableau ca ne sert à rien. Lorsque tu passes un tableau en argument, tu passes automatiquement l'adresse de son premier élément (indice 0).
    Mon Site
    Ma bibliothèque de gestion des chaînes de caractères en C

    L'imagination est plus importante que le savoir. A. Einstein

    Je ne répond à aucune question technique par MP, merci d'avance !

  5. #5
    Membre averti
    Inscrit en
    Octobre 2007
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 16
    Par défaut
    franck tu n'aurais pas la solution ? Pourquoi quand je compile ca marque pa du tout la valeur attendu

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 67
    Par défaut
    je viens enfin de comprendre ton ennoncé...dsl

    (je propose une petite solution que je n'ai pas compilé mais s'il y a des erreurs de compilation tu le feras....)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
     
    unsigned char i, tmp, resultat = 0;
    printf("Donner votre valeur :\n");
    for(i=0; i<8; i++)
    {
        scanf(%d,&tmp);
        resultat = (1<<resultat) + tmp;
    }
    voilou j'ai ecrit le plus simplement pour que ca soit le plus comprehensible.!!!

  7. #7
    Membre averti
    Inscrit en
    Octobre 2007
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 16
    Par défaut
    en gros ce que je doit faire c'est
    -Je rentre une valeur en binaire de 1octet
    -Je doit la prendre avec scanf en chaine de caractère
    -et pour finir avec un printf je dois l'afficher en entier

    je dois utilisé une boucle et a peu prés le meme système que j'ai fais la avec le test

  8. #8
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Par défaut
    Citation Envoyé par Franck.H Voir le message
    Dans le cas d'une variable tu le passes mais dans le cas d'un tableau ca ne sert à rien. Lorsque tu passes un tableau en argument, tu passes automatiquement l'adresse de son premier élément (indice 0).
    Non seulement ça ne sert à rien, mais c'est faux de le mettre. Soit tableau un tableau de char, par exemple. Il y a une différence fondamentale entre tableau et &tableau. Le type!

    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  9. #9
    Membre averti
    Inscrit en
    Octobre 2007
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 16
    Par défaut
    je suis DEBUTANT je suis en premiere année geii j'apprend l'algo je ne peux pa tout voir du premier cour alor désolé si je fait des erreur pour vous " choquante" alors que moi je ne les vois pa forcément

    merci de votre compréhension

  10. #10
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 67
    Par défaut
    De plus

    est un tableau de 9 caracteres c'est a dire 72 bits, si j'ai bien compris tu ve manipuler un octet c'est a dire 8 bit alors je te conseil d'utiliser

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    unsigned char cbin;

  11. #11
    Membre averti
    Inscrit en
    Octobre 2007
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 16
    Par défaut
    Ca me met une erreur bon c'est dur et dire que j'ai controle la dessus

  12. #12
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par darkewne Voir le message
    mais ce que j'ai fais ne marche pas pouvez vous me corrigé ??
    Déjà, tu peux corriger ça :
    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
     
    Project   : Forums
    Compiler  : GNU GCC Compiler (called directly)
    Directory : C:\dev\forums\
    --------------------------------------------------------------------------------
    Switching to target: default
    Compiling: main.c
    main.c:3: warning: return type defaults to `int'
    main.c:3: warning: function declaration isn't a prototype
    main.c: In function `main':
    main.c:7: warning: implicit declaration of function `printf'
    main.c:8: warning: implicit declaration of function `scanf'
    main.c:18: warning: int format, pointer arg (arg 2)
    main.c:19: warning: implicit declaration of function `system'
    main.c:4: warning: 'val' might be used uninitialized in this function
    Linking console executable: console.exe
    Process terminated with status 0 (0 minutes, 7 seconds)
    0 errors, 7 warnings
    Après corrections,
    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
     
    #include <stdio.h>
     
    int main (void)
    {
       int i, val, result;
       char cbin[9];
     
       printf ("rentrez valeur : ");
       scanf ("%s", cbin);
       for (i = 0; i < 8; i++)
       {
          result = val & (1 << i);
          if (result == 0)
             cbin[7 - i] = 48;
          else
             cbin[7 - i] = 49;
       }
       cbin[8] = 0;
       printf ("la nouvelle valeur est : %s \n", cbin);
       return 0;
    }
    il reste ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    Project   : Forums
    Compiler  : GNU GCC Compiler (called directly)
    Directory : C:\dev\forums\
    --------------------------------------------------------------------------------
    Switching to target: default
    Compiling: main.c
    main.c: In function `main':
    main.c:5: warning: 'val' might be used uninitialized in this function
    Linking console executable: console.exe
    Process terminated with status 0 (0 minutes, 0 seconds)
    0 errors, 1 warnings

  13. #13
    Membre averti
    Inscrit en
    Octobre 2007
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 16
    Par défaut
    sur mon pc j'ai aucune erreur c'est juste je compile je met la valeur par ex
    00001000
    et il me marque
    2293584
    en gros il dit n'importe quoi alor qu'il devrait imarqué
    8




    ok merci chez moi il y a toujours pas de message d'erreur mais sa se rapproche un pe plus deja

  14. #14
    Membre averti
    Inscrit en
    Octobre 2007
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 16
    Par défaut
    enfaite non sa change rien vu que il me faut le valeur en entier
    je rentre 00001000==>il affiche 8
    vous avez juste mis ====> %s a la place de %d

  15. #15
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par darkewne Voir le message
    ok merci chez moi il y a toujours pas de message d'erreur mais sa se rapproche un pe plus deja
    Bah oui, ton compilateur est sans doute mal réglé :

    http://emmanuel-delahaye.developpez....tm#cfg_compilo

    Le dernier message que j'ai signalé indique que la variable 'val' n'est jamais initialisée. Or, c'est bien le problème. Tu saisies une chaine, mais tu ne la transformes pas en valeur numérique.

    Il manque une conversion avec strtol(), par exemple.

  16. #16
    Membre averti
    Inscrit en
    Octobre 2007
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 16
    Par défaut
    enfaite la boucle sert a prendre chaque bit un par un dans le tableau pour aprés en faire une valeur binaire.

    je prends le bits de rang 0 dans le tableau je test avec le "masque" et je regarde si c'est egale a 1 ou 0 et comme sa je reforme la valeur que j'ai tapé a l'ordi en valeur binaire

    est comme ça je peut la transformer en ce que je veux

  17. #17
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par darkewne Voir le message
    enfaite la boucle sert a prendre chaque bit un par un dans le tableau pour aprés en faire une valeur binaire.

    je prends le bits de rang 0 dans le tableau je test avec le "masque" et je regarde si c'est egale a 1 ou 0 et comme sa je reforme la valeur que j'ai tapé a l'ordi en valeur binaire

    est comme ça je peut la transformer en ce que je veux
    Oui, j'ai bien compris, merci ! Mais ce qu'il manque c'est une conversion de la chaine saisie (cbit) en valeur numérique (val).

    Tu ne comprends pas ce que j'écris ?

  18. #18
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    Si j'ai compris ton problème correctement, une solution :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    int main (void)
    {
       int i ;
       char cbin[9];
       int result=0;
       printf ("rentrez valeur : ");
       scanf ("%8s", cbin);
       for (i = 0; i <8 && cbin[i] != 0; i++)
          result = result*2+ cbin[i]-'0';
       printf ("la nouvelle valeur est : %d \n", result);
       return 0;
    }

Discussions similaires

  1. Décalage de bits
    Par Kraz dans le forum VB 6 et antérieur
    Réponses: 10
    Dernier message: 21/10/2006, 18h09
  2. décalages de bits
    Par seb95 dans le forum Java ME
    Réponses: 4
    Dernier message: 05/03/2006, 04h03
  3. décalage de bits
    Par cedre22 dans le forum Langage
    Réponses: 13
    Dernier message: 17/01/2006, 09h33
  4. Multiplication par décalage de bits
    Par tekman54000 dans le forum Assembleur
    Réponses: 2
    Dernier message: 25/10/2005, 11h35
  5. Décalage de bit sur unsigned char [8]
    Par dboulange dans le forum C++
    Réponses: 14
    Dernier message: 26/07/2005, 14h10

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