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 :

Problème de temps d'éxécution.


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Mars 2013
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2013
    Messages : 2
    Par défaut Problème de temps d'éxécution.
    Bonjour à tous!
    C'est mon premier message sur le forum et j'espère poster dans la bonne catégorie.
    Je pose une question ici car j'ai un problème de temps d'éxécution sur un algorithme.
    Je dois écrire un programme qui prends en entrée 2 entiers, nbr1 et nb2, et qui renvoie les arrangements possibles de ces deux entiers.
    je m'exprime mal , donc voici un exemple:
    Si nbr1 = 5 et nbr2 = 3,
    on a en sortie :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    1 2 3 
    1 2 4 
    1 2 5 
    1 3 4 
    1 3 5 
    1 4 5 
    2 3 4 
    2 3 5 
    2 4 5 
    3 4 5
    Ou encore, si nbr1 = 4 et nbr2 = 3,
    sortie :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    1 2 3 
    1 2 4 
    1 3 4 
    2 3 4
    Les contraintes d'entrées sont 1 <= nbr1,nbr2 <= 100

    J'ai écris un algorithme qui visiblement marche, mais est trop long au niveau du temps d'éxécution. ( temps minimal : 1,5 s sur une machine à 1GHz)

    Voila mon algorithme :


    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
    #include <iostream>
     
    using namespace std;
     
    int pile[100];
     
    void fonction ( int nbrcours, int choisi , int debut, int choisidepart)
    {
       if ( choisi != 0 ) 
       {
          for ( int k = debut ; k <= nbrcours ; k++ )
          {
             pile[choisidepart - choisi] = k;
             fonction ( nbrcours , choisi - 1 , k + 1 , choisidepart);
             pile[choisidepart - choisi] = 0;
          }
       }
       else
       {
          for ( int k1 = 0 ; k1 < choisidepart ; k1++)
          {
             cout << pile[k1] << " ";
          }
          cout << '\n';
       }
    }
     
    int main()
    {
       int nb1 , nb2;
       cin >> nb1 >> nb2;
       fonction ( nb1 , nb2 , 1 , nb2);  
    }
    Je n'ai aucune idée pour diminuer le temps d'éxécution, je vous demande donc votre aide, si vous avez une idée.. Merci d'avance

    Stanne.

  2. #2
    Membre Expert
    Avatar de transgohan
    Homme Profil pro
    Développeur Temps réel Embarqué
    Inscrit en
    Janvier 2011
    Messages
    3 149
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Temps réel Embarqué

    Informations forums :
    Inscription : Janvier 2011
    Messages : 3 149
    Par défaut
    Supprimes les affichages pour vérifier que la majorité du temps ne se passe pas en accès console.

    Après tu peux optimiser l'accès au tableau en utilisant des pointeurs plutôt que des index.
    Car à chaque fois que tu marques pile[choisidepart - choisi] tu parcours le tableau depuis l'index 0 à chaque fois.

  3. #3
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Salut,
    Citation Envoyé par transgohan Voir le message
    Après tu peux optimiser l'accès au tableau en utilisant des pointeurs plutôt que des index.
    Car à chaque fois que tu marques pile[choisidepart - choisi] tu parcours le tableau depuis l'index 0 à chaque fois.
    Non, malheureux!!!

    Les tableaux donnent la certitude que les objets sont contigus en mémoire, et que l'adresse de chaque élément en mémoire est clairement connue.

    Tu as donc une garantie d'accès en temps constant (il faut juste le temps de faire l'addition / la soustraction )

    Les cas d'utilisation de pointeurs sont particulièrement limités en C++, et nous ne pourront jamais cautionner leur utilisation en dehors de ces quelques cas bien précis.

    D'autant plus que là, tu proposes, en plus, d'utiliser l'arithmétique des pointeurs qui, bien que n'étant pas forcément difficile, reste néanmoins particulière
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    301
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 301
    Par défaut
    ben y'a quand même une boucle (cf. parties en gras plus bas). Sinon +1 pour revoir l'algo et éviter la récursivité.

    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
    #include <iostream>
     
    using namespace std;
     
    int pile[100];
     
    void fonction ( int nbrcours, int choisi , int debut, int choisidepart)
    {
       if ( choisi != 0 ) 
       {
          int& elt = pile[choisidepart - choisi];
          for ( int k = debut ; k <= nbrcours ; k++ )
          {
             elt = k;
             fonction ( nbrcours , choisi - 1 , k + 1 , choisidepart);
             elt = 0;
          }
       }
       else
       {
          for ( int k1 = 0 ; k1 < choisidepart ; k1++)
          {
             cout << pile[k1] << " ";
          }
          cout << '\n';
       }
    }
     
    int main()
    {
       int nb1 , nb2;
       cin >> nb1 >> nb2;
       fonction ( nb1 , nb2 , 1 , nb2);  
    }

  5. #5
    Membre Expert
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2012
    Messages
    1 711
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2012
    Messages : 1 711
    Par défaut
    Hello,

    Met ton code dans les balises [ code] ça sera plus simple à lire.

    Sinon, évite la récursion si possible (utilise une stack par exemple) tu gagnera probablement pas mal.

    Puis... essaye de revoir ton algo si possible, actuellement t'a une complexité en O(n!) (j'ai pas compris le problème, donc je sais pas si c'est possible)

    edit:
    Citation Envoyé par transgohan Voir le message
    Après tu peux optimiser l'accès au tableau en utilisant des pointeurs plutôt que des index.
    Car à chaque fois que tu marques pile[choisidepart - choisi] tu parcours le tableau depuis l'index 0 à chaque fois.
    pile[choisidepart - choisi] est équivalent à pile + (choisidepart - choisi)*sizeof(int) (à quelques casts près).
    Il n'y à pas de parcours entier, on gagnerai juste une addition, une soustraction et une multiplication par itération si on stockait l'adresse de pile[choisidepart - choisi]. (?)

  6. #6
    Membre Expert
    Avatar de transgohan
    Homme Profil pro
    Développeur Temps réel Embarqué
    Inscrit en
    Janvier 2011
    Messages
    3 149
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Temps réel Embarqué

    Informations forums :
    Inscription : Janvier 2011
    Messages : 3 149
    Par défaut
    Citation Envoyé par Iradrille Voir le message
    edit:
    pile[choisidepart - choisi] est équivalent à pile + (choisidepart - choisi)*sizeof(int) (à quelques casts près).
    Il n'y à pas de parcours entier, on gagnerai juste une addition, une soustraction et une multiplication par itération si on stockait l'adresse de pile[choisidepart - choisi]. (?)
    C'était en ce sens que je parlais de parcours. Ma formulation était mal choisie (partir de l'adresse pointée par 0 et la décaler de x = parcours / déplacement / ect).

    Quand je parlais de supprimer les affichages c'était pour savoir si le temps d'affichage était prépondérant à ton traitement. Généralement on n'affiche que rarement, on traite les données.
    Donc si à terme tu vas stocker les données au lieu de les afficher autant regarder tout de suite si cet affichage est ce qui te pose problème.

    Tu peux aussi passer à une version non récursive de ton algo.

    Et sinon une piste (que je n'ai pas lu) : http://www.developpez.net/forums/d1445/autres-langages/algorithmes/algo-trouver-arrangement-combinaison-delements/

  7. #7
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Mars 2013
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2013
    Messages : 2
    Par défaut
    Je ne comprends pas bien la phrase "supprimer les affichages". Pour les pointeurs, je viens de découvrir cette notion et je n'y suis pas du tout familier.
    Cela permettrait de faire diminuer la compléxité de l'algorithme ?

Discussions similaires

  1. [MySQL] Problème temps d'éxécution trop long
    Par Yo. dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 13/06/2006, 14h55
  2. Réponses: 5
    Dernier message: 09/05/2005, 12h24
  3. temps d'éxécution et ressources
    Par Tchinkatchuk dans le forum Décisions SGBD
    Réponses: 5
    Dernier message: 12/04/2005, 09h11
  4. [OpenGL] Problème de Vitesse d'éxécution
    Par stick059 dans le forum OpenGL
    Réponses: 9
    Dernier message: 19/11/2004, 13h57
  5. [MFC] : CTime ? Calcul de temps d'éxécution
    Par jonzuzu dans le forum MFC
    Réponses: 10
    Dernier message: 25/05/2004, 14h22

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