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 :

MATRICE / LISTE chainée


Sujet :

C

  1. #1
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    109
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 109
    Par défaut MATRICE / LISTE chainée
    SALU à tous
    je demande juste comment peut_on representer une matrice avec les listes linaires chainée..... je parle du chainage entre les maillons. je serai tres reconnaissante si quelqu'un m'aide
    merci pour l'aide

  2. #2
    Membre émérite
    Avatar de Elijha
    Homme Profil pro
    Ingénieur développement matériel électronique
    Inscrit en
    Avril 2003
    Messages
    314
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement matériel électronique
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Avril 2003
    Messages : 314
    Par défaut
    Bonsoir,

    Tu trouveras un très bon cours sur les listes chainées ici : "Les listes chaînées en langage C".

  3. #3
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 860
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 860
    Billets dans le blog
    1
    Par défaut
    Salut

    Généralement le but d'une liste chainée est de pouvoir insérer facilement des éléments au milieu de la liste. On modifie juste 2 pointeurs. Alors que pour insérer un élément au milieu d'un tableau, il faut agrandir le tableau puis décaler tous les éléments qui suivent l'insertion.

    Dans une matrice, je ne vois pas trop l'utilité d'implanter une liste chainée vu que la matrice est généralement quelque chose de figé dans sa taille. Et donc je ne comprends pas que tu ailles te priver des possibilités du tableau (pouvoir balayer tout un tableau avec un simple décalage) parce que tu t'orientes sur une technologie peu utilisée habituellement dans les objets que tu manipules.

    Tu voudrais bien nous apporter quelques précisions STP ?
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  4. #4
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    109
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 109
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Salut

    Généralement le but d'une liste chainée est de pouvoir insérer facilement des éléments au milieu de la liste. On modifie juste 2 pointeurs. Alors que pour insérer un élément au milieu d'un tableau, il faut agrandir le tableau puis décaler tous les éléments qui suivent l'insertion.

    Dans une matrice, je ne vois pas trop l'utilité d'implanter une liste chainée vu que la matrice est généralement quelque chose de figé dans sa taille. Et donc je ne comprends pas que tu ailles te priver des possibilités du tableau (pouvoir balayer tout un tableau avec un simple décalage) parce que tu t'orientes sur une technologie peu utilisée habituellement dans les objets que tu manipules.

    Tu voudrais bien nous apporter quelques précisions STP ?
    TOUT à fait d'accord avec toi mais ce travaille ma était imposé je peux rien dire!!! c'est pour ça je cherche des idéés!!!

    avant que j'oublie la matrice que j'ai n'est pas gifée... elle est en fonction des (l,L) largeur*longueur entré par l'utilisateur

  5. #5
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    109
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 109
    Par défaut
    Citation Envoyé par Elijha Voir le message
    Bonsoir,

    Tu trouveras un très bon cours sur les listes chainées ici : "Les listes chaînées en langage C".
    merci pour le lien mais c'est dommage je cherche pas ça ........ je cherche UNE matrice en liste chainé!!!!!

  6. #6
    Membre émérite
    Avatar de Elijha
    Homme Profil pro
    Ingénieur développement matériel électronique
    Inscrit en
    Avril 2003
    Messages
    314
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement matériel électronique
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Avril 2003
    Messages : 314
    Par défaut
    Bonjour,

    Serait-ce plus ça (voir miniature) ?
    Images attachées Images attachées  

  7. #7
    Expert confirmé
    Avatar de Mat.M
    Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2006
    Messages
    8 540
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 8 540
    Par défaut
    Salut,

    Citation Envoyé par sali2801 Voir le message
    TOUT à fait d'accord avec toi mais ce travaille ma était imposé je peux rien dire!!! c'est pour ça je cherche des idéés!!!

    avant que j'oublie la matrice que j'ai n'est pas gifée... elle est en fonction des (l,L) largeur*longueur entré par l'utilisateur
    eh bien il faut faire des listes chainées...de listes chainées..

    ( c'est comme en C++ pour faire des std::vector<std::vector>> )

    Quand tu construits la liste il faut allouer un pointeur qui va pointer sur un autre pointeur d'une première liste chainée puis une deuxième etc..en fait des pointeurs de pointeurs.

  8. #8
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    109
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 109
    Par défaut
    Citation Envoyé par Elijha Voir le message
    Bonjour,

    Serait-ce plus ça (voir miniature) ?
    OUI C'est EXACTEMENT ce que je cherche à realiser.....peux_ tu m'aider

  9. #9
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    109
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 109
    Par défaut
    Citation Envoyé par Mat.M Voir le message
    Salut,



    eh bien il faut faire des listes chainées...de listes chainées..

    ( c'est comme en C++ pour faire des std::vector<std::vector>> )

    Quand tu construits la liste il faut allouer un pointeur qui va pointer sur un autre pointeur d'une première liste chainée puis une deuxième etc..en fait des pointeurs de pointeurs.
    votre reponse me parait interessante mais j'arrive pas à imaginer ce que vous voulez dire...une explication s'il vous plait

  10. #10
    Expert confirmé
    Avatar de Mat.M
    Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2006
    Messages
    8 540
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 8 540
    Par défaut
    Eh bien selon l'exemple du tutoriel il faut déclarer un node **p;
    par contre il faut modifier la fonction pour ajouter des éléments.

  11. #11
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 860
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 860
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Mat.M Voir le message
    Eh bien selon l'exemple du tutoriel il faut déclarer un node **p;
    Sûrement pas. Un node **p suppose que tu pointes vers quelque chose pointant vers l'élément utile (donc 2 indirections) alors que dans le schéma, chaque item possède deux flèches chacune d'elle pointant vers un item identique donc chaque flèche étant une simple indirection...

    Citation Envoyé par sali2801 Voir le message
    OUI C'est EXACTEMENT ce que je cherche à realiser.....peux_ tu m'aider

    Code c : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    typedef struct s_item {
         int valeur;
         struct s_item *next_col;
         struct s_item *next_lig;
    } t_item;
     
    typedef struct {
        t_item *first;
        unsigned int nb_lig;
        unsigned int nb_col;
    } t_matrice;
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  12. #12
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    109
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 109
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Code c : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    typedef struct s_item {
         int valeur;
         struct s_item *next_col;
         struct s_item *next_lig;
    } t_item;
     
    typedef struct {
        t_item *first;
        unsigned int nb_lig;
        unsigned int nb_col;
    } t_matrice;
    DESOLé mais le problem persiste encore je crois que c'est plus un problem de declaration de structure mais plutot du chainage ......
    j'ai décidé par exemple de créé le premeir maillon qui a deux tetes ( vertical/horizontal) ces deux tetes seront sauvegarder dans deux tableaux dynamique de taille colonne/ligne
    à partir de ce fameux maillon je fais une boucle qui vas me créer la premier liste horizontale chaque maillon a une tete sauvegardeé dans le tableauLigne

    ET ouppps je sais plus comment finir mon idéé

    mes idéés sont_elles bonnes???? aide moi

  13. #13
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 860
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 860
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par sali2801 Voir le message
    j'ai décidé par exemple de créé le premeir maillon qui a deux tetes ( vertical/horizontal) ces deux tetes seront sauvegarder dans deux tableaux dynamique de taille colonne/ligne
    Mouais. Tant qu'à utiliser des tableaux, autant alors mettre toute ta matrice en simple tableau 2D quoi...

    Citation Envoyé par sali2801 Voir le message
    ET ouppps je sais plus comment finir mon idéé
    Ben c'est un peu la preuve qu'elle est pas terrible. Déjà tu dis que chaque maillon a 2 têtes. Or, un maillon n'a qu'une adresse. Ensuite tu veux stocker ces 2 têtes dans des tableaux. Ce n'est alors plus de la liste chainée mais simplement du tableau.

    Elijha t'a montré le schéma. Chaque maillon possède l'adresse du maillon suivant situé sur la même ligne et du maillon suivant situé sur la même colonne. Et j'ai codé ce schéma en C pour te montrer le principe. Maintenant si tu ne veux plus faire de la liste chainée c'est toi qui voit...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  14. #14
    Membre émérite
    Avatar de Elijha
    Homme Profil pro
    Ingénieur développement matériel électronique
    Inscrit en
    Avril 2003
    Messages
    314
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement matériel électronique
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Avril 2003
    Messages : 314
    Par défaut
    Bonsoir,

    Il y a peut-être un moyen plus simple. C'est de ne pas lier les toutes les colonnes ensembles, mais seulement la première. En gros tu te retrouves avec une liste chainée pour la première colonne et une liste chainé par ligne. Un petit dessin ? (voir miniature).
    La gestion en sera simplifiée, par contre il faudra changer ton algorithme de parcours de ton tableau.

    Décompose ton programme en fonctions de plus bas niveau. Par exemple, tu peux te créer deux fonctions; une qui te créer une liste simplement chainée (ligne), et une autre qui te libère la liste.
    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
    s_item *newLigne(int nbCellule)
    {
        // Retourne un pointeur sur une liste de nbCellules
    }
     
    void freeLigne(s_item **ligne)
    {
        // Libère la mémoire d'une liste
    }
     
    int newMatrix(int nbLigne, int nbColonne, t_matrice *matrix)
    {
         // Pour nbColonne (liées) allouer nbLignes
    }
     
    void freeMatrix(t_matrice *matrix)
    {
        // Libère la mémoire d'une matrice
    }
     
    int main(void)
    {    t_matrice matrix ;
     
         newMatrix(10, 10 &matrix) ;
     
         // Ici tu peux naviguer dans ta matrice
     
        freeMatrix(&matrix) ;
     
        return 0 ;
    }
    Images attachées Images attachées  

Discussions similaires

  1. Réponses: 12
    Dernier message: 08/02/2005, 23h42
  2. Bibliothèque de listes chainées
    Par gege2061 dans le forum C
    Réponses: 29
    Dernier message: 17/12/2004, 20h15
  3. copie de liste chainée
    Par tomsoyer dans le forum C++
    Réponses: 15
    Dernier message: 31/08/2004, 18h20
  4. Trie liste chaine
    Par Congru dans le forum C
    Réponses: 2
    Dernier message: 30/03/2004, 19h05
  5. tri de liste chainée
    Par RezzA dans le forum C
    Réponses: 7
    Dernier message: 26/01/2003, 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