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

Algorithmes et structures de données Discussion :

[complexité algo] recurrence avec changement de variable


Sujet :

Algorithmes et structures de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de rvfranck
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2004
    Messages
    746
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2004
    Messages : 746
    Par défaut [complexité algo] recurrence avec changement de variable
    Bonjour,

    Dans un exo on me demande de démontrer que T(n)=O(n) avec:
    T(n) = T((n/2) + racine(n)) + n pour tout n>16

    J'ai tenté d'effectuer un changement de variable pour avoir une recurrence linéaire, mais je n'y arrive pas.
    Pourriez vous m'indiquer les changements de variables à faire, ou alors une autre méthode pour resoudre mon problème?

    Merci d'avance.

  2. #2
    Membre Expert Avatar de Nemerle
    Inscrit en
    Octobre 2003
    Messages
    1 106
    Détails du profil
    Informations personnelles :
    Âge : 54

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 106
    Par défaut
    Qu'appelles-tu récurrence linéaire? Et dans T(n) = T((n/2) + racine(n)) + n, le n/2 est bien la division entière? Dans ce cas, c'est explicite, tu as une profondeur n/2 pour atteindre T(1)...

  3. #3
    Membre éclairé Avatar de rvfranck
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2004
    Messages
    746
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2004
    Messages : 746
    Par défaut
    Merci,

    J'entends par recurrence lineaire une recurrence où T(n) est exprimé en fonction de T(n-k) avec k entier naturel. quelque chose comme ça T(n) = T(n-1) + T(n-2). oui, n/2 est bien la division entière.
    On me demande de démontrer... vous avez une idée?

  4. #4
    Membre Expert Avatar de Nemerle
    Inscrit en
    Octobre 2003
    Messages
    1 106
    Détails du profil
    Informations personnelles :
    Âge : 54

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 106
    Par défaut
    difficile de remplacer une division par une soustraction

  5. #5
    Expert confirmé

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    facile !!!!!

    C'est dans les ordres de grandeur....

    srqt(n) < n/2 pour tout n >= 3

    Donc des que l'on atteint 4, T(n/2+sqrt(n)) est deja calcule

    Donc

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     pour i = 4 a i = N
     
        Pour calculer T(i), il faut ajouter a i quelque chose qui est deja calcule.
    Donc le calcul de T(N) sera proportionnel a N....

    CQFD

  6. #6
    Membre Expert Avatar de Nemerle
    Inscrit en
    Octobre 2003
    Messages
    1 106
    Détails du profil
    Informations personnelles :
    Âge : 54

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 106
    Par défaut
    D'accord avec toi, mais tu n'as pas changé l'eau / en vin -

  7. #7
    Membre éclairé Avatar de rvfranck
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2004
    Messages
    746
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2004
    Messages : 746
    Par défaut
    Je voulais m'inspirer de ce qu'a dit Souviron

    Citation Envoyé par souviron34 Voir le message
    facile !!!!!

    C'est dans les ordres de grandeur....

    srqt(n) < n/2 pour tout n >= 3

    Donc des que l'on atteint 4, T(n/2+sqrt(n)) est deja calcule

    Donc

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     pour i = 4 a i = N
     
        Pour calculer T(i), il faut ajouter a i quelque chose qui est deja calcule.
    Donc le calcul de T(N) sera proportionnel a N....

    CQFD
    Lorsqu'on dépasse une certaine valeur, pour moi 22, T(n/2 + sqrt(n)) est déjà calculé et il vaut O(n). ce qui fait que T(n) = T(n/2 + sqrt(n)) + n va donner O(n).

    Mais comme je l'ai lu dans un post, il faut tout prouver mathématiquement.


  8. #8
    Membre éclairé Avatar de rvfranck
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2004
    Messages
    746
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2004
    Messages : 746
    Par défaut
    Citation Envoyé par millie Voir le message
    T'as montré que T(n) est en O(n), mais rien sur sa complexité.

    La fonction suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    T : n =
     si n = 0 retourner 0
     sinon retourner T(n-1)
    Sa complexité est en O(n) mais la fonction est nulle
    Voici mon premier post sur le sujet,

    Citation Envoyé par rvfranck Voir le message
    Bonjour,

    Dans un exo on me demande de démontrer que T(n)=O(n) avec:
    T(n) = T((n/2) + racine(n)) + n pour tout n>16

    J'ai tenté d'effectuer un changement de variable pour avoir une recurrence linéaire, mais je n'y arrive pas.
    Pourriez vous m'indiquer les changements de variables à faire, ou alors une autre méthode pour resoudre mon problème?

    Merci d'avance.
    Je ne comprends pas ce que tu essais de me dire!!!

  9. #9
    Rédacteur

    Avatar de millie
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    7 015
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 015
    Par défaut
    Ok, j'ai toujours cru qu'on parlait de complexité, au temps pour moi.

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

Discussions similaires

  1. [MySQL] affichage aleatoire d'une variable avec changement au bout d'un temps donné
    Par spokito dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 28/07/2011, 20h02
  2. Probleme de date avec changement d'année
    Par GrisburT dans le forum Oracle
    Réponses: 11
    Dernier message: 30/11/2004, 16h15
  3. Evenement avec changement d'enregistrement
    Par SegmentationFault dans le forum Bases de données
    Réponses: 4
    Dernier message: 13/08/2004, 15h30
  4. Probleme avec changement du mot de passe utilisateur
    Par Davenico dans le forum Outils
    Réponses: 2
    Dernier message: 19/12/2003, 14h42
  5. Procédure avec un nombre variable d'arguments
    Par charly dans le forum Langage
    Réponses: 15
    Dernier message: 21/06/2002, 11h08

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