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 :

Division binaire avec reste.


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2012
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2012
    Messages : 11
    Par défaut Division binaire avec reste.
    Bonjour, je dois faire la division d'un message binaire par un polynôme générateur traduit en binaire. J'ai décider de coder de la manière suivante:

    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
     
    int degre_polynome(suite_binaire s_b)
    {
    	int i,degre=s_b.taille;
     
    	for(i=0;i<s_b.taille;i++)
    	{
    		if(s_b.bit[i]==1)
    		{
    				degre=s_b.taille-i;
    				i=s_b.taille;
    		}
    		else
    			degre-=1;
    	}
     
    	return degre;
    }
     
    suite_binaire div_polynomiale(suite_binaire m_b,suite_binaire g)
    {
    	suite_binaire reste=m_b;
    	int i,curseur1=0,curseur2=g.taille;
    	int nb_decalage=0;
    	int a=0,b=0;
     
    	while(degre_polynome(reste)>degre_polynome(g))
    	{
    		for(i=curseur1;i<curseur2;i++)
    		{
    			if(m_b.bit[i]==1 && g.bit[i-nb_decalage]==1)
    				reste.bit[i]=0;
    			else if(m_b.bit[i]==0 && g.bit[i-nb_decalage]==0)
    				reste.bit[i]=0;
    			else
    				reste.bit[i]=1;
    		}
     
    		a=curseur1,b=curseur2;
    		for(i=a;i<b;i++)
    		{	
    			if(reste.bit[i]==0)
    			{
    				nb_decalage+=1;
    				curseur1+=1;
    				curseur2+=1;
    			}
    		}
    	}
    	return reste;
    }
    Je cherche donc à savoir si le degré le plus haut du reste est plus grand que celui du polynôme générateur (soit le premier 1 rencontré). Je suis cependant confronté à une erreur de segmentation. Pouvez m'aider et me conseiller sur la manière de procéder? Merci d'avance.

  2. #2
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 026
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 026
    Par défaut
    Bonjour,

    Une erreur de segmentation survient lorsque tu essaye de toucher à une zone mémoire non-allouée ou qui a déjà été désallouée.
    Ceci arrive parfois lorsqu'on utilise des pointeurs sans les avoir initialisés.

    Lorsqu'on a une erreur de segmentation, le mieux est d'utiliser un debogueur pour trouver la ligne à laquelle l'erreur de segmentation est lancée.

  3. #3
    Modérateur

    Avatar de Bktero
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2009
    Messages
    4 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Juin 2009
    Messages : 4 493
    Billets dans le blog
    1
    Par défaut
    Peux-tu nous montrer la définition de la structure suite_binaire ainsi que la façon dont tu initialises les structures de ce type avant de les passer à tes fonctions ?

Discussions similaires

  1. Réponses: 8
    Dernier message: 18/04/2011, 14h46
  2. division avec reste ?
    Par neufrdb dans le forum Algorithmes et structures de données
    Réponses: 2
    Dernier message: 11/03/2011, 23h48
  3. Afficher un arbre binaire avec sa structure
    Par PhoneKilleR dans le forum C
    Réponses: 7
    Dernier message: 23/04/2008, 23h24
  4. Réponses: 1
    Dernier message: 11/09/2005, 02h04
  5. Arbre binaire avec la STL ?
    Par SteelBox dans le forum SL & STL
    Réponses: 9
    Dernier message: 10/11/2004, 13h22

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