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

Delphi Discussion :

type ensemble ordonné ?


Sujet :

Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Avatar de OutOfRange
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    533
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 533
    Par défaut type ensemble ordonné ?
    Bonjour
    Donc la question est simple
    Une variable de type set of est-elle "ordonnée" ?
    [0,1,2]=[2,0,1] ou [0,1,2]<>[2,0,1]

    Peut-on désigner le nième élément de l'ensemble ?
    Un truc du genre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    var
    MonEnsemble:set of byte;
    ...
    MonEnsemble(1):=16;
    D'après ce que j'ai lu ici ou là, la réponse est non, mais je voudrais en avoir confirmation

    Merci

  2. #2
    Membre Expert
    Avatar de LadyWasky
    Femme Profil pro
    Inscrit en
    Juin 2004
    Messages
    2 932
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 55
    Localisation : France, Hauts de Seine (Île de France)

    Informations forums :
    Inscription : Juin 2004
    Messages : 2 932
    Par défaut
    Salut,

    J'ai deux réponses à t'apporter :

    Mathématiquement : non
    Un ensemble, c'est comme un grand sac dans lequel tu mets tous les éléments pêle-mêle, il n'y a donc pas vraiment d'ordre là-dedans. Chaque élément n'existe toutefois au maximum qu'en un seul exemplaire.



    Dans Delphi : non et oui
    d'abord je cite Delphi
    Citation Envoyé par l'aide Delphi
    Un ensemble est une collection de valeurs ayant le même type scalaire. Les valeurs n'ont pas d'ordre intrinsèque, une même valeur ne peut donc pas apparaître deux fois dans un ensemble.
    En interne "Le grand sac" est une sorte de tableau d'au maximum 256 bits numérotés de 0 à 255 (donc répartis sur 8 entiers de 32 bits), d'ailleurs, c'est pour ça qu'en Delphi on ne peut avoir que des ensembles de types qui ne contiennent au maximum que 256 valeurs (donc un Set of Byte, c'est OK, un Set of Cardinal est interdit)
    Si ton type de base ne contient que 8 valeurs, le tableau créé par Delphi sera plus petit

    Si ton ensemble est un array of byte et que dans ton ensemble tu mets
    Les bits n°3 et n°12 seront "allumés" et les autres "éteints".

    Là ou on peut dire que l'ensemble est ordonné dans Delphi, c'est que le tableau de bit est lui-même ordonné. mais que tu fasses :
    ça
    ou ça
    à l'arrivé, se seront toujours les mêmes bits qui seront allumés.

    donc à l'arrivé, tu aura toujours ceci :
    Du coup ceci est toujours vrai
    [0,1,2]=[2,0,1]
    et ceci est toujours faux :
    Maintenant, tu comprends aussi pourquoi tu ne peux pas choisir où mettre ton 16, Delphi allume forcément le bit n°16 pour toi dans son tableau.

    Si tu as besoin d'une sorte d'ensemble ordonné, les tableaux dynamiques sont tes amis

  3. #3
    Membre Expert
    Avatar de e-ric
    Homme Profil pro
    Apprenti chat, bienfaiteur de tritons et autres bestioles
    Inscrit en
    Mars 2002
    Messages
    1 568
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Apprenti chat, bienfaiteur de tritons et autres bestioles

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 568
    Par défaut
    Citation Envoyé par OutOfRange
    Bonjour
    Donc la question est simple
    Une variable de type set of est-elle "ordonnée" ?
    [0,1,2]=[2,0,1] ou [0,1,2]<>[2,0,1]

    Peut-on désigner le nième élément de l'ensemble ?
    Un truc du genre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    var
    MonEnsemble:set of byte;
    ...
    MonEnsemble(1):=16;
    D'après ce que j'ai lu ici ou là, la réponse est non, mais je voudrais en avoir confirmation

    Merci
    Salut

    Pour tester l'appartenance à un ensemble, il faut utiliser l'opérateur in
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
      if toto in [toto,titi] then...
    pour ajouter un élément dans un ensemble:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    var
      s: Set of byte;
    begin
      s := s + [1];
    pour retirer un élément:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    var
      s: Set of byte;
    begin
      s := [1,2,3];
      s := s - [1];
    cdlt

    e-ric

    M E N S . A G I T A T . M O L E M
    Debian 64bit, Lazarus + FPC -> n'oubliez pas de consulter les FAQ Delphi et Pascal ainsi que les cours et tutoriels Delphi et Pascal

    "La théorie, c'est quand on sait tout, mais que rien ne marche. La pratique, c'est quand tout marche, mais qu'on ne sait pas pourquoi. En informatique, la théorie et la pratique sont réunies: rien ne marche et on ne sait pas pourquoi!".
    Mais Emmanuel Kant disait aussi : "La théorie sans la pratique est inutile, la pratique sans la théorie est aveugle."

  4. #4
    Membre éclairé
    Avatar de OutOfRange
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    533
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 533
    Par défaut
    @waskol
    Merci pour ces explications techniques, qui confirment ce que j'entrevoyais
    @ e-ric
    OK mais ce n'est pas la manipulation des ensembles qui me posait pb
    Merci qd mm

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

Discussions similaires

  1. Accès à un ensemble ordonné sur l'insertion
    Par Kreatore dans le forum C++
    Réponses: 11
    Dernier message: 08/01/2014, 10h34
  2. opérations sur type ensemble
    Par OutOfRange dans le forum Langage
    Réponses: 8
    Dernier message: 02/07/2009, 22h30
  3. Ensemble ordonné et liste de successeur
    Par phuongthao dans le forum Algorithmes et structures de données
    Réponses: 6
    Dernier message: 29/01/2008, 22h55
  4. Type ENSEMBLE (intersection, soustraction etc)
    Par DURVILLE dans le forum Delphi
    Réponses: 13
    Dernier message: 30/04/2007, 19h33
  5. [Tableaux] Le type Ensemble existe-t-il ?
    Par petitnuage dans le forum Langage
    Réponses: 3
    Dernier message: 08/06/2006, 20h21

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