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 :

BinarySearch sur clef dans une List<T>


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Par défaut BinarySearch sur clef dans une List<T>
    Bonjour

    Est il possible de définir un ICompareur sur une liste T qui prentds comme argument un élément de la liste et un objet différent (une clef string par exemple)

    Le but est evidement de pouvoir faire une recherche sur clef sans devoir definir un element clef pour l'ocassion

    J'espere ne pas etre trop confus

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Par défaut
    Euh, c'est pas complètement clair pour moi
    Dans le titre tu parles de recherche binaire... mais pour faire ce type de recherche, il faut d'abord que la liste soit triée.
    De toutes façons, si tu veux faire des recherches par clef, il vaudrait mieux utiliser un Dictionary
    Ou alors j'ai pas du tout compris ce que tu cherches à faire, et il faudrait que tu expliques mieux

  3. #3
    Membre expérimenté
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Par défaut
    Salut Tomlev

    Ok, je me disais bien que je n'etais pas tres clair

    Donc, j'ai une List<T>

    Cette liste se compose d'éléments Entity

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    class Entity
    {
       string Nom;
       int ID;
       double valeur;
    }
    Cette liste est triée sur un des membre de ses eléments disons le noms

    Je definis un compareur pour cela

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
        class EntityIDComparer : IComparer<Entity>
        {
          public int Compare(Entity obj1, Entity obj2)
          {
            int dif = (obj1.Nom.CompareTo(obj2.Nom));
            return dif;  // on pourrait faire -dif pour sortDirection.Descending
          }
        }
    Maintenant j'aimerais faire un BinarySearch mais en donnant comme clef non pas un element Entity mais un string ?

    En définissant un autre compareur bien sur


    Est ce possible

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Par défaut
    ah ok...
    non, je ne crois pas que ce soit possible
    par contre, tu peux tout à fait utiliser comme clef un Entity "bidon" dont tu as mis la propriété Nom à la valeur que tu veux, et utiliser le comparer que tu as défini

  5. #5
    Membre expérimenté
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Par défaut
    Merci Tomlev

    Oui c'est effectivement ce que je fais normalement
    Mais dans le cas present, le malin qui a ecrit le code avant moi a mis dans le constructeur de son entité un tas de bazar casse bonbon avec des membres privates qui rendent la chose un peu fastidieuse

    Par contre je viens de trouver un lien d'un autre génie (un bon)
    Qui a du etre confronté au meme probleme, il a eu peu réinventé la roue mais avec quelques accessoires en plus :


    http://www.removingalldoubt.com/perm...4-acd1c7a4a1e3

  6. #6
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Par défaut
    Ah oui, c'est effectivement ce qu'on appelle réinventer la roue
    Mais si tu es en C#3, tu peux faire tout simplement comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Entity entity = (from e in listEntities where e.Nom == "leNomRecherché" select e).FirstOrDefault();
    Par contre la recherche sera linéaire et non binaire... si la liste n'est pas très longue, ça n'a pas vraiment d'importance

Discussions similaires

  1. Evenement sur item dans une liste
    Par bilou69 dans le forum Flex
    Réponses: 11
    Dernier message: 18/12/2009, 11h46
  2. Ouvrir fichier sur lien hypertexte dans une liste
    Par JimmyB dans le forum Access
    Réponses: 10
    Dernier message: 18/10/2006, 15h28
  3. Recherche sur 2 elements dans une liste box.
    Par molarisapa dans le forum Access
    Réponses: 2
    Dernier message: 29/05/2006, 18h43
  4. Réponses: 1
    Dernier message: 29/09/2005, 11h10
  5. fuite de memoire dans une liste de pointeur sur composant
    Par Nicolos_A dans le forum Composants VCL
    Réponses: 2
    Dernier message: 16/12/2004, 08h46

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