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 :

Plus petit nombre listes chainées itérativement


Sujet :

C

  1. #1
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2008
    Messages
    391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2008
    Messages : 391
    Points : 84
    Points
    84
    Par défaut Plus petit nombre listes chainées itérativement
    Bonjour je cherche le plus petit nombre et le plus grand nombre d'une liste chainé de façon itérative et j'ai essayé un truc mais cela ne fonctionne pas ; pouvez vous m'aider !


    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
    #include <stdio.h>
    #include <stdlib.h>
     
    typedef struct t_element t_element;
    struct t_element
        {
        int valeur;
        struct t_element *pt_suivant;
        };
     
        typedef struct liste liste;
        struct liste
        {
        struct t_element*pt_tete;
        };
     
    int main()
    { 
        liste la_liste;
        t_element* pt_courant = la_liste.pt_tete;
        int min = 0;
        int max = 0;
        min=pt_courant->valeur;
        max=pt_courant->valeur;
     
        pt_courant = pt_courant ->pt_suivant;
                   while (pt_courant=!NULL)
                         { 
                         if(pt_courant->valeur>max)
                             {
                             max<-pt_courant->valeur;
                             }
                         if (pt_courant->valeur<min)
                             {
                             min<-pt_courant->valeur;
                             }
                             pt_courant=pt_courant->pt_suivant;
                          }
        printf("%d\n",min);
        printf("%d",max);
     
    system("PAUSE");	
    return 0;
    }

  2. #2
    Expert éminent sénior
    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
    Points : 13 926
    Points
    13 926
    Par défaut
    Mais, tu as oublié de créer la liste dont tu cherches les plus petit et plus grand éléments.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
        liste la_liste;
        t_element* pt_courant = la_liste.pt_tete;
    la_liste n'est pas initialisée. Conséquence : la_liste.pt_tete vaut n'importe quoi.
    Publication : Concepts en C

    Mon avatar : Glenn Gould

    --------------------------------------------------------------------------
    Une réponse vous a été utile ? Remerciez son auteur en cliquant le pouce vert !

  3. #3
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2008
    Messages
    391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2008
    Messages : 391
    Points : 84
    Points
    84
    Par défaut
    Et donc je dois faire quoi ?
    Car je galère sur ce problème depuis un petit moment !

  4. #4
    Expert éminent sénior
    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
    Points : 13 926
    Points
    13 926
    Par défaut
    La première chose est d'ajouter des éléments à ta liste. Au départ, la liste est vide et doit être marquée comme tel.
    Schématiquement :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    int main(void)
    { 
        liste la_liste;
        la_liste.pt_tete = NULL;  // la liste est vide
        AjouterListe(&la_liste, 10);
        AjouterListe(&la_liste, 3);
        AjouterListe(&la_liste, 5);
    ....
    // recherche du max/min
    ....
    Il te faut écrire une fonction qui ajoute des éléments dans la liste
    Publication : Concepts en C

    Mon avatar : Glenn Gould

    --------------------------------------------------------------------------
    Une réponse vous a été utile ? Remerciez son auteur en cliquant le pouce vert !

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

Discussions similaires

  1. Sélectionner les 10 plus petits nombres pairs non listés
    Par Antoine_935 dans le forum Requêtes
    Réponses: 7
    Dernier message: 06/05/2011, 13h36
  2. Afficher nombres listes chainées
    Par Devilju69 dans le forum C
    Réponses: 5
    Dernier message: 11/03/2008, 15h20
  3. Mettre en couleur le plus petit nombre d'une ligne
    Par vatsyayana dans le forum Excel
    Réponses: 7
    Dernier message: 20/02/2008, 14h49
  4. Réponses: 52
    Dernier message: 13/03/2007, 15h07
  5. Trouver le plus petit nombre
    Par IDE dans le forum Algorithmes et structures de données
    Réponses: 6
    Dernier message: 22/10/2006, 09h36

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