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

Turbo Pascal Discussion :

Mettre en temps constant


Sujet :

Turbo Pascal

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Inscrit en
    Mai 2011
    Messages
    30
    Détails du profil
    Informations forums :
    Inscription : Mai 2011
    Messages : 30
    Par défaut Mettre en temps constant
    Bonjour, je souhaite mettre cette implantation en temps constant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    type
      ABin = ^_CellABin;
      _CellABin =
        record
         _suivG, _suivD : ABin
        end;
     
    function Hauteur (a : ABin) : integer;
    begin
      if EstVide(a) then
        Hauteur := 0
      else
        Hauteur := 1 + max(Hauteur(SAGauche(a)), Hauteur(SADroit(a)))
    end;
    (toutes les fonctions utilisées dans hauteur sont supposées définies)

    J'ai mis ça pour que ce soit en temps constant mais ça n'a pas l'air correct :
    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
    type
      ABin = ^_CellABin;
      _CellABin =
        record
         _suivG, _suivD : ABin;
         _haut : integer;
        end;
     
    function Hauteur (a : ABin) : integer;
    begin
      if EstVide(a) then
        Hauteur := 0
      else
        Hauteur := a^._haut;
    end;

  2. #2
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 967
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 967
    Par défaut
    Woe,

    Il est déconseillé de commencer les identifiants par _, c'est généralement réservé à l'implémentation du compilateur, et de toute manière, ça n'ajoute rien à la lisibilité, au contraire.

    Pour le temps constant, c'est pratiquement impossible pour une fonction si courte, tant en code qu'en exécution. Ça va - entre autres - dépendre du processeur, du moment de l'appel (par exemple : le code est-il déjà dans la mémoire cache ? Est-il appelé dans une suite linéaire d'instructions ou après un saut ? ...).

    De plus, le code lui-même implique que le temps d'exécution change selon le résultat du test :
    Déjà, le processeur ne mettra pas le même temps pour arriver dans un cas ou l'autre, et là-dessus s'ajoute :
    ramené au code généré, il s'agit d'une affectation d'une valeur immédiate.
    alors qu'ici on a une indirection (usage d'un pointeur), d'où accès au pointeur suivi de l'accès à la valeur.

  3. #3
    Membre actif
    Inscrit en
    Mai 2011
    Messages
    30
    Détails du profil
    Informations forums :
    Inscription : Mai 2011
    Messages : 30
    Par défaut
    Oui, c'est sûr que sa ne sera pas tout à fait le même temps si c'est égal à 0..
    Mais est ce que c'est correct au moins ?

Discussions similaires

  1. Somme en temps constant
    Par Virgile le chat dans le forum Mathématiques
    Réponses: 6
    Dernier message: 03/07/2014, 00h24
  2. mettre un temps de mesure
    Par vaness038 dans le forum LabVIEW
    Réponses: 3
    Dernier message: 08/06/2009, 18h41
  3. transformer [i][j] en [k] avec accès en temps constant
    Par Benoit_T dans le forum SL & STL
    Réponses: 4
    Dernier message: 12/05/2009, 10h09
  4. [c#] Mettre une constante dans un Boundfield
    Par oyigit dans le forum ASP.NET
    Réponses: 3
    Dernier message: 13/12/2006, 15h44
  5. Réponses: 3
    Dernier message: 19/05/2006, 11h37

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