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

Collection et Stream Java Discussion :

Tableau sans doublons


Sujet :

Collection et Stream Java

  1. #1
    Inactif
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    83
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 83
    Points : 43
    Points
    43
    Par défaut Tableau sans doublons
    Bonjour !

    Voici un exo :
    Ecrire une fonction qui, étant donné un tableau de nombres entiers, renvoie un tableau dont les éléments sont ceux du tableau incident, mais sans les doublons.

    Exemple : 2 21 36 11 2 54 36 2 58 6
    la fonction renverra : 2 21 36 11 54 58 6
    ça a l' air facile comme ça. Mais j' ai du mal. Trouver la taille du tableau renvoyé est surtout mon problème. J' ai alors pensé à des collections Set, HashSet, TreeSet... Mais je vois que des problèmes de conversions sont compliqués et j' en suis arrivé à plus de 10 lignes de code. Ce qui commença à m' inquiéter.

    Ma question est toute simple : Pourrais-je résoudre le problème sans collections ? Auquel cas, je reviens à ma première réflexion. Si non, suis-je forcé de passer par des collections. Et dans ce cas, pour ceux qui ont déjà résolu ce problème, quelle est la classe qui permet d' y arriver.
    Les classes de type collection qui permettent de créer des objets n' acceptant pas de doublons n' ont pas de méthodes pour accéder à un élément. A moins que je n' ai pas compris. L' anglais est un peu ma bête noire et je regarde les docs de Java sur sa plate forme. Et bine sûr, elle est en anglais.

    Je ne demande pas pour l' instant la solution, mais plutôt une direction. Où aller ?

    Merci d ' avance.

  2. #2
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Octobre 2004
    Messages
    398
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2004
    Messages : 398
    Points : 710
    Points
    710
    Par défaut
    Citation Envoyé par raph707
    Bonjour !

    Voici un exo :


    ça a l' air facile comme ça. Mais j' ai du mal. Trouver la taille du tableau renvoyé est surtout mon problème. J' ai alors pensé à des collections Set, HashSet, TreeSet... Mais je vois que des problèmes de conversions sont compliqués et j' en suis arrivé à plus de 10 lignes de code. Ce qui commença à m' inquiéter.



    Les classes de type collection qui permettent de créer des objets n' acceptant pas de doublons n' ont pas de méthodes pour accéder à un élément. A moins que je n' ai pas compris. L' anglais est un peu ma bête noire et je regarde les docs de Java sur sa plate forme. Et bine sûr, elle est en anglais.

    Je ne demande pas pour l' instant la solution, mais plutôt une direction. Où aller ?

    Merci d ' avance.
    pour les collections, je pense que tu as une fonction get(i) qui te renvoie le ième élément ajouté dans ta collection
    quand au HashSet, il certifie que tu n'as pas de doublons dans ta liste
    tu peux donc ajouter des Integer, si l'objet à ajouter existe deja, il ne sera pas ajouté en théorie

  3. #3
    Inactif
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    83
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 83
    Points : 43
    Points
    43
    Par défaut
    La méthode get(i) appartient à quelle classe exactement. J' ai cherché dans HashSet, je n' ai pas vu. Même dans les méthodes dites inherited , provenant de l' héritage, je n' ai pas trouvé get().

    Merci d' avance pour la réponse !

  4. #4
    Inactif
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    83
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 83
    Points : 43
    Points
    43
    Par défaut
    Citation Envoyé par franck06
    pour les collections, je pense que tu as une fonction get(i) qui te renvoie le ième élément ajouté dans ta collection
    quand au HashSet, il certifie que tu n'as pas de doublons dans ta liste
    tu peux donc ajouter des Integer, si l'objet à ajouter existe deja, il ne sera pas ajouté en théorie

    Petite question qui pourrait m' aider... Existe t il la notion d' héritage entre deux interfaces ?

  5. #5
    Nouveau membre du Club
    Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2006
    Messages
    38
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 38
    Points : 38
    Points
    38
    Par défaut
    Trouver la taille du tableau renvoyé est surtout mon problème.
    En quoi est ce un problème? Si tu as une fonction qui retourne un tableau d'int, tu n'a pas besoin de connaitre la taille de celui ci ! De plus tu peux faire un
    Fk

  6. #6
    Rédacteur
    Avatar de benwit
    Profil pro
    dev
    Inscrit en
    Septembre 2004
    Messages
    1 676
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : dev

    Informations forums :
    Inscription : Septembre 2004
    Messages : 1 676
    Points : 4 265
    Points
    4 265
    Par défaut
    Oui, une interface peut en étendre une autre.

    Dans ton cas :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    // Tableau initial
    int[] values = {2, 21, 36, 11, 2, 54, 36, 2, 58, 6};
     
    HashSet<Integer> noDoublons = new HashSet<Integer>();
    for(int val : values)
       if (! noDoublons.contains(val))
           noDoublons.add(val);
     
    // Pour avoir le nouveau tableau
    noDoublons.toArray();

    Tout le monde savait que c'était impossible. Il est venu un imbécile qui ne le savait pas et qui l'a fait. Marcel PAGNOL
    On ne savait pas que c'était impossible, alors on l'a fait. John Fitzgerald KENNEDY.
    L'inexpérience est ce qui permet à la jeunesse d'accomplir ce que la vieillesse sait impossible. Paul (Tristant) BERNARD
    La meilleure façon de prédire l'avenir, c'est de l'inventer.

  7. #7
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    429
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 429
    Points : 475
    Points
    475
    Par défaut
    Bonjour,

    Le problème avec le HashSet, c'est que l'ordre des éléments n'est pas garanti.
    Si tu veux garder le même ordre que dans le tableau de départ, tu peux utiliser une ArrayList, en gérant les doublons.

    Nicolas

    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    // appeler le fichier Test.java
    // par Nicolas_75
    // lundi 19 février 2007
    // pour http://www.developpez.net/forums/showthread.php?t=282001
     
    import java.util.ArrayList;
     
    public class Test {
     
        public static void main(String[] args) {
     
            int[] values = {2, 21, 36, 11, 2, 54, 36, 2, 58, 6};
     
            // création d'une ArrayList sans doublon :
            ArrayList<Integer> temp = new ArrayList<Integer>();
            for (int i=0; i<values.length; i++) {
                if (!temp.contains(new Integer(values[i]))) {
                    temp.add(new Integer(values[i]));
                }
            }
     
            // création du nouveau tableau :
            int[] result = new int[temp.size()];
            for (int i=0; i<temp.size(); i++) {
                result[i] = temp.get(i);
            }
     
            // affichage du résultat :
            System.out.println("Résultat :");
            if (result.length>0) {
                System.out.print(result[0]);
                if (result.length>1) {
                    for (int i=1; i<result.length; i++) {
                        System.out.print(" "+result[i]);
                    }
                }
            }
            System.out.println();
        }
    }

Discussions similaires

  1. [XL-2010] extraire des données sans doublon d'un tableau
    Par RobertThi dans le forum Excel
    Réponses: 6
    Dernier message: 20/01/2014, 16h03
  2. Réponses: 7
    Dernier message: 08/06/2012, 16h24
  3. Comment remplir un tableau avec random sans doublon ?
    Par muntu dans le forum Collection et Stream
    Réponses: 15
    Dernier message: 16/07/2010, 09h42
  4. tableau de valeurs sans doublons à arrondis
    Par fraid49 dans le forum Général Python
    Réponses: 6
    Dernier message: 15/10/2009, 09h19
  5. remplir un tableau sans doublons ...
    Par ryo-san dans le forum C
    Réponses: 22
    Dernier message: 10/11/2005, 12h43

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