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 :

Lenteur inexpliquée d'une fonction


Sujet :

C++

  1. #1
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2011
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2011
    Messages : 41
    Points : 84
    Points
    84
    Par défaut Lenteur inexpliquée d'une fonction
    Bonsoir,

    Pour vous aider à situer la chose, en résumant, j'ai implanter l'algorithme de dijkstra sur des graphes en C++ avec la file de priorité tableau décroissant.
    Je le fais afin de faire des test pratique sur les tableaux décroissants puis ensuite les tas binomiaux.

    Après avoir créé mes différentes classes, je me rends compte (après plusieurs test) que ce qui ralenti mon programme est la récupération du poids de 2 arrêtes, voici le code :

    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
    class Voisin
    {
    private:
    	int _sommet;
    	double _poids;
    [...]
    };
     
    class TabVoisin
    {
    private:
    	list<Voisin> _liste;
    	Point _coordonnee;
    [...]
    };
     
    class Graphe
    {
    private:
    	int _nbsommet;
    	vector<TabVoisin> _tableau;
    public:
    [...]
    double Poids(int u, int v);
    [...]
    };
     
    double Graphe::Poids(int u, int v)
    //On est sûr que u et v sont relié
    {
    	vector<TabVoisin> TV=this->get_TabVoisin();
    	TV[u].get_liste();
    	list<Voisin> L=TV[u].get_liste();//Renvoie _liste
    	while(!L.empty())
    	{
    		if(L.front().get_sommet()==v)
    			return L.front().get_poids();
    		L.pop_front();
    	}
    }

    Pour être sûr que c’est cette fonction qui me fait lagger, mon programme se lance en 2 secondes quand je remplace ce code par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    double Graphe::Poids(int u, int v)
    //On est sûr que u et v sont relié
    {
    return(1);
    }
    Et lorsque je le laisse, il mets plusieurs minutes à se lancer. Le graphe possède 200 sommets avec environ une 40aine d'arrêtes par sommet.
    Une explication :/ ?

  2. #2
    Invité
    Invité(e)
    Par défaut
    hello,

    à chaque fois tu copies tes tableaux
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    vector<TabVoisin> TV=this->get_TabVoisin();
    list<Voisin> L=TV[u].get_liste();//Renvoie _liste
    Donc forcément, c'est lent si t'as mass de noeuds.

    pourquoi utiliser get_TabVoisin et pas directement _tableau.
    const list<Voisin> &l = _tableau[u].get_liste();

    (avec const &std::list<Voisin> TabVoisin::get_liste()const (note surtout la référence))
    Et après au lieu de popper ta liste (pourquoi une liste et pas un set?), tu itères simplement: (avec std::find_if ou à la main comme ci-dessous)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    	for(std::list<Voisin>::const_iterator it=l.begin(); it!=l.end(); ++it)
    	{
    		if(it->get_sommet()==v)
    			return it->get_poids();
    	}

  3. #3
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2011
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2011
    Messages : 41
    Points : 84
    Points
    84
    Par défaut
    Bonjour,

    Comme quoi c'est en pratiquant que l'on apprends :/. Et je vois aussi pourquoi il aurait été plus malin d'utiliser un set plutôt qu'une liste.

    En tout cas merci, tu avais raison ! Grace à toi je vais passer un meilleur week-end (oui ça me faisait déprimer :p).

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

Discussions similaires

  1. [XL-2007] Lenteur inexpliquée d'une propriété.
    Par Scutigere dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 29/10/2013, 15h55
  2. Lenteur d'exécution d'une fonction (avec curseur)
    Par labolabs dans le forum PL/SQL
    Réponses: 8
    Dernier message: 07/06/2011, 07h29
  3. Lenteur à l'utilisation d'une fonction dans une clause WHERE
    Par lacombefr dans le forum Développement
    Réponses: 2
    Dernier message: 06/04/2010, 19h50
  4. [Turbo Pascal] Allocation et désallocation de pointeurs dans une fonction
    Par neird dans le forum Turbo Pascal
    Réponses: 13
    Dernier message: 17/11/2002, 20h14
  5. Une fonction avec des attributs non obligatoires
    Par YanK dans le forum Langage
    Réponses: 5
    Dernier message: 15/11/2002, 13h39

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