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

Mathématiques Discussion :

Aide au calcul de la complexité de deux boucles imbriquées


Sujet :

Mathématiques

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    103
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 103
    Points : 110
    Points
    110
    Par défaut Aide au calcul de la complexité de deux boucles imbriquées
    Bonjour,

    J'ai besoin d'aide pour calculer la complexité de deux boucles imbriquées avec une structure suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    for i in 1..n
        for j in k_1..k_n 
        ...
    endfor
    endfor
    où k_1 + ... +k_n = n.

    Je dirais que la complexité de ces boucles imbriquées est O(n) puisqu'on rentre n fois dans chacune des boucles.
    J'aimerais que vous me le confirmiez et que vous m'indiquiez comment le prouver correctement.

    Merci d'avance,
    Arnaud

  2. #2
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    eh bien c'est faux

    Pour chaque itération de la boucle i, tu as k_n itérations de la boucle j.

    Comme au total tu auras n itérations, tu auras donc une complexité en O(n*k_n).

    Comme k_1+...k_n vaut n, ce sera donc O(n2)
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    103
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 103
    Points : 110
    Points
    110
    Par défaut
    Oups,

    Je suis désolé, une erreur s'est glissée dans le pseudo-code. Il fallait lire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    for i in 1..n
        for j in 1..k_i 
        ...
    endfor
    endfor
    et toujours k_1+...+k_n = n.

    Donc, je voudrais montrer que :
    -1ère itération de la boucle i : k_1 opérations
    -2ème itération de la boucle i : k_2 opérations
    ...
    -n-ème itération de la boucle i : k_n opérations

    Merci.

  4. #4
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    comme me l'a rappelé si bien Nebulix ici

    1+2+3+...+n=n*(n-1)/2 ~O(n²)

    Donc ta double boucle est donc bien en O(n2)..
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    103
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 103
    Points : 110
    Points
    110
    Par défaut
    Merci pour la réponse, mais je ne suis toujours pas convaincu.
    Votre formule est valable pour une boucle de la forme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    for i in 1..n
        for j in 1..i 
        INSTR
    endfor
    endfor
    puisque dans ce cas là, on a :
    -1ère itération de la boucle i : 1 opérations
    -2ème itération de la boucle i : 2 opérations
    ...
    -n-ème itération de la boucle i : n opérations
    Soit un total de 1 + 2 + ... + n = n(n+1)/2 (et non n(n -1)/2)

  6. #6
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par nono_31 Voir le message
    Soit un total de 1 + 2 + ... + n = n(n+1)/2 (et non n(n -1)/2)
    ça s'appelle se tirer dans le pied

    n(n-1)/2 = n2/2 -n/2

    Comme on n'est pas à une constante près, c'est dominé par n2


    Que ce soit n(n-1)/2 ou n(n+1)/2...
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    103
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 103
    Points : 110
    Points
    110
    Par défaut
    Bon évidemment, je ne dois pas être très clair.

    Que ce soit n(n-1)/2 ou n(n+1)/2...
    Je voulais juste corriger la formule de Gauss sur la somme des nombres de 1 à n.
    Pour la petite histoire, un professeur fatigué désirant un moment de tranquillité et demande à ses élèves de sommer les nombres de 1 à 100.
    Il est très surpris quand le jeune Gauss lui présente le résultat 5mn plus tard.
    Cette formule repose sur l'observation suivantes :
    1 + n = n+1
    2 + (n -1) = n+1
    ...
    k + (n-k+1) = n+1
    ...
    (n-1) + 2 = n+1
    (n) + 1 = n+1
    Soit un total de n(n+1)/2

    Ensuite, la formule de Gauss s'applique à une boucle de la forme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    for i in 1..n
        for j in 1..i 
        INSTR
    endfor
    endfor
    Mais pas dans mon cas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    for i in 1..n
        for j in 1..k_i
        INSTR
    endfor
    endfor
    où k_1+...+k_n = n.

  8. #8
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par nono_31 Voir le message
    Mais pas dans mon cas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    for i in 1..n
        for j in 1..k_i
        INSTR
    endfor
    endfor
    où k_1+...+k_n = n.
    je re-répète :

    à chaque itération i, tu fais k_i itérations...

    C'est donc borné par n..

    Et la complexité est la borne...
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  9. #9
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    103
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 103
    Points : 110
    Points
    110
    Par défaut
    Je comprends votre raisonnement :

    Raisonnement 1
    boucle i : O(n)
    boucle j : k_i < n -> O(n)
    une borne supérieure sur la complexité au pire cas est O(n^2).

    Raisonnement 2
    Mais, je crois qu'une analyse plus fine montre que ces deux boucles imbriquées sont équivalentes au parcours d'un tableau T en deux dimensions où
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    T = [
    [1, ..., k_1],
    [1, ..., k_2]
    ...
    [1, ... , k_i],
    ...
    [1, ..., k_n]
    ];
    On considère que T[i] =null si la valeur de k_j est 0.
    Le tableau T a (k_1 + ...+ k_i+ ... + k_n) éléments, soit n éléments.
    La complexité d'un tel parcours est O(n).

    Ma question est donc : est-il possible de contredire le raisonnement 2 ?

  10. #10
    Membre actif Avatar de Acrim
    Profil pro
    En recherche d'emploi
    Inscrit en
    Septembre 2010
    Messages
    134
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : En recherche d'emploi

    Informations forums :
    Inscription : Septembre 2010
    Messages : 134
    Points : 204
    Points
    204
    Par défaut
    Bonjour, je ne veux pas trop m'éloigner du sujet initial mais les paramètres me laisse un peu perplexe.

    Citation Envoyé par nono_31 Voir le message
    où k_1 + ... +k_n = n.
    Autrement dit, pour tout j dans [1,n] k_j = 1 ? (en supposant que les k_j sont des entiers positifs)
    « La science informatique n'est pas plus la science des ordinateurs que l'astronomie n'est celle des télescopes. » — Edsger Dijkstra

  11. #11
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    103
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 103
    Points : 110
    Points
    110
    Par défaut
    Autrement dit, pour tout j dans [1,n] k_j = 1 ? (en supposant que les k_j sont des entiers positifs)
    Non, on suppose que 0 <= k_i <= n.
    Si k_i = 0, la condition entrée dans la boucle n'est pas vérifiée.
    Pour le tableau, si k_i = 0, alors on considère que T[i] est l'élément null.

  12. #12
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    Citation Envoyé par nono_31 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    for i in 1..n
        for j in 1..k_i 
        ...
    endfor
    endfor
    et toujours k_1+...+k_n = n.
    Ca me semble équivalent à ca
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    @call mafonction(k_1) // effectue k_1 fois l'operation
    @call mafonction(k_2) // effectue k_2 fois l'operation
    @call mafonction(k_3) // effectue k_3 fois l'operation 
    ...
    @call mafonction(k_n) // effectue k_n l'operation
     
    func mafonction(k) // effectue k fois l'opération
      for j in 1..k
        /* operation */
      endfor  
    endfunc
    Au total on effectue donc k_1+...+k_n = n fois l'opération.
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  13. #13
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    103
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 103
    Points : 110
    Points
    110
    Par défaut
    Merci pour cette confirmation

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

Discussions similaires

  1. Sortir de deux boucles imbriquées
    Par Hedidams dans le forum Débuter
    Réponses: 9
    Dernier message: 08/01/2018, 00h28
  2. éviter deux boucles imbriquées
    Par Décembre dans le forum MATLAB
    Réponses: 3
    Dernier message: 17/12/2010, 15h37
  3. Deux Boucles imbriquées
    Par Telecaster dans le forum Langage
    Réponses: 2
    Dernier message: 04/10/2010, 15h27
  4. [Batch] faire deux boucles imbriques
    Par fk04 dans le forum Scripts/Batch
    Réponses: 3
    Dernier message: 17/03/2010, 12h32
  5. [JSTL] Deux boucles imbriquées
    Par Esil2008 dans le forum Taglibs
    Réponses: 1
    Dernier message: 31/07/2007, 18h46

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