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 :

nombre le lignes communs


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de étoile de mer
    Profil pro
    Étudiant
    Inscrit en
    Avril 2007
    Messages
    978
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2007
    Messages : 978
    Par défaut nombre le lignes communs
    bonjour à tous ,
    JE possède deux listes chainées stockant pour chaque mot la listes des lignes où il aparaît
    par exemple le mot:
    bonjour (1,1,2,3)
    good(1,1,,2,2,3,5)
    je veux faire une fonction qui determine le nombre de lignes communs , là dans cet exemple c'est égal à 3 (1,2,3)
    là jai fait 2 boucle imbriquées parcourant les 2 listes de lignes mais jarrive pas ignorer les lignes redondants
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    int nbrLignesCommunes(ChainonMot const * pc,ChainonMot const * pc2)
    {
        int nbr=0;
        ChainonCoord const *pcCoord;
    	ChainonCoord const *pcCoord2;
    	for(pcCoord = coord_GetPremierC(GetPtrCoordC(pc)) ; pcCoord!=NULL ; pcCoord=coord_GetNextC(pcCoord))
    	{
    	for(pcCoord2 = coord_GetPremierC(GetPtrCoordC(pc2)) ; pcCoord2!=NULL ; pcCoord2=coord_GetNextC(pcCoord2))
    		{
    		    if(GetLigne(pcCoord2)==GetLigne(pcCoord))
    		    nbr++;
    }
    Une idée svp?
    merci

  2. #2
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 397
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 397
    Par défaut
    Il manque la définition des structures ChainonMot et ChainonCoord...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Membre éclairé Avatar de étoile de mer
    Profil pro
    Étudiant
    Inscrit en
    Avril 2007
    Messages
    978
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2007
    Messages : 978
    Par défaut
    Merci Médinoc
    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
    struct st_chainonMot
    {
    	struct st_chainonMot *suivant;
    	int nbLignes;
    	size_t cchTailleMot;
    	ListeCoord coords;
    	char mot[1];
    };
     
     
    typedef struct st_chainonMot ChainonMot;
     
    typedef struct st_liste
    {
    	ChainonMot *pPremier;
    } ListeMot;
     
    typedef ListeMot TableHachageMot[TAILLEHASH];

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    typedef struct st_chainonCoord ChainonCoord;
     
    typedef struct st_listeCoord
    {
    	ChainonCoord *pPremiere;
    } ListeCoord;

  4. #4
    Membre émérite Avatar de SofEvans
    Homme Profil pro
    Développeur C
    Inscrit en
    Mars 2009
    Messages
    1 084
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Développeur C

    Informations forums :
    Inscription : Mars 2009
    Messages : 1 084
    Par défaut
    On a pas assez d'element pour repondre exactement, mais la reponse sera proche de ceci (Les ??? et les commentaire sont les element incertains):

    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
     
    /* Permettra de parcourir les deux liste (FR et AN) */
    int i, j;
    /* Permet de verifier si le numero de la ligne n'est pas deja compter dans la solution */
    int k;
     
    /* Tableau dynamique */
    int *LigneCommune = (int*) malloc (sizeof(int));
    int nombreDeSolution = 0;
     
     
     
    for (i=0 ; i< ??? ; i++)
        for (j=0 ; j< ??? ; j++)
            if (/* Condition permettant de savoir si ligne[i] == ligne[j] */)
            { 
                /* Se comportera comme un booleen */
                int nouvelleLigne = 1;
     
                /* On va chercher a savoir si la ligne est deja presente */
                for (k=0 ; k<nombreDeSolution ; k++)
                    if (LigneCommune[k] == /*Ligne[i]*/)
                        nouvelleLigne = 1;
     
                if (nouvelleLigne)
                {
                    ligneCommune[nombreDeSolution] = /*Ligne[i]*/;
                    nombreDeSolution++;
                    int *Temporaire = realloc(LigneCommune, sizeof(int)*(nombreDeSolution + 1));
                    if (Temporaire != NULL)
                    { 
                         free(LigneCommune);
                         LigneCommune = Temporaire;
                    }
                    else 
                    {
                        printf ("Probleme lors du realloc !");
                        exit(1);
                    }
                }
     
     
            }
    Le code est non tester !!
    Je redoute notamment des probleme avec realloc (je n'aime pas cette fonction). Il y a peut etre aussi quelque erreur d'ecriture, meme si j'ai essayer de faire attention.

  5. #5
    Membre éclairé Avatar de étoile de mer
    Profil pro
    Étudiant
    Inscrit en
    Avril 2007
    Messages
    978
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2007
    Messages : 978
    Par défaut Une erreur de compilation
    Re,
    j'ai crée un tableau dynamique "ligneCommune", mais le compilateur ne le reconnait pas, il maffiche :
    erreur: ‘ligneCommune’ undeclared (first use in this function)
    Bizarre
    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
    int nbrLignesCommunes(ChainonMot const * pc,ChainonMot const * pc2)
    {
    /* Permettra de parcourir les deux liste (FR et AN) */
     ChainonCoord const *pcCoord;
    ChainonCoord const *pcCoord2;
    /* Permet de verifier si le numero de la ligne n'est pas deja compter dans la solution */
    int k;
     
    /* Tableau dynamique */
    int *LigneCommune = (int*) malloc (sizeof(int));
    int nombreDeSolution = 0;
     
     
     
    for(pcCoord = coord_GetPremierC(GetPtrCoordC(pc)) ; pcCoord!=NULL ; pcCoord=coord_GetNextC(pcCoord))
    	{
    	for(pcCoord2 = coord_GetPremierC(GetPtrCoordC(pc2)) ; pcCoord2!=NULL ; pcCoord2=coord_GetNextC(pcCoord2))
    		{
            if (GetLigne(pcCoord) == GetLigne(pcCoord2))
            {
     
                /* Se comportera comme un booleen */
                int nouvelleLigne = 1;
                 if(LigneCommune  == NULL)
                 {
                     printf("!!!!");
                     exit(1);
                }
     
    //
    //            /* On va chercher a savoir si la ligne est deja presente */
                for (k=0 ; k<nombreDeSolution ; k++)
                    if (LigneCommune[k] == GetLigne(pcCoord))
                        nouvelleLigne = 1;
     
    //
                if (nouvelleLigne)
                {
                    ligneCommune[nombreDeSolution] = GetLigne(pcCoord);
                    nombreDeSolution++;
                    int *Temporaire = realloc(LigneCommune, sizeof(int)*(nombreDeSolution + 1));
                    if (Temporaire != NULL)
                    {
                       free(LigneCommune);
                         LigneCommune = Temporaire;
                  }
                    else
                    {
                        printf ("Probleme lors du realloc !");
                        exit(1);
                    }
                }
     
            }
            }
    		}
     
    	return nombreDeSolution;
    }

  6. #6
    Membre émérite Avatar de orfix
    Homme Profil pro
    Inscrit en
    Avril 2007
    Messages
    707
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2007
    Messages : 707
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    LigneCommune[nombreDeSolution] = GetLigne(pcCoord);

  7. #7
    Membre éclairé Avatar de étoile de mer
    Profil pro
    Étudiant
    Inscrit en
    Avril 2007
    Messages
    978
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2007
    Messages : 978
    Par défaut
    oops
    Merci ssmario

Discussions similaires

  1. Nombre de lignes en commun dans une table
    Par Elpix dans le forum Requêtes
    Réponses: 2
    Dernier message: 06/02/2015, 17h07
  2. Savoir le nombre de lignes communes deux dataframe
    Par Stepsbysteps dans le forum R
    Réponses: 2
    Dernier message: 30/04/2013, 19h08
  3. Réponses: 49
    Dernier message: 26/05/2010, 21h58
  4. Réponses: 2
    Dernier message: 02/03/2004, 19h38
  5. [TListView] Compter le nombre de lignes
    Par agh dans le forum Composants VCL
    Réponses: 2
    Dernier message: 30/09/2002, 20h25

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