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

avec Java Discussion :

Problème avec indexOf


Sujet :

avec Java

  1. #1
    Membre régulier
    Profil pro
    Doctorant
    Inscrit en
    Février 2011
    Messages
    258
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2011
    Messages : 258
    Points : 88
    Points
    88
    Par défaut Problème avec indexOf
    Bonjour ;
    j'ai une liste chainée je l'ai triée dans une autre liste maintenant je veux récupérer l'index des trois premiers éléments


    liste originale :[5, 6, 8, 4, 15, 11, 2, 4]

    liste triée :[2, 4, 4, 5, 6, 8, 11, 15]
    l'indexof des trois premiers éléments de la liste triée [6, 3, 3]

    le problème c'est quand il y'a des valeurs qui se répètent comme le 4 ici ,
    normalement j'aurai 6,3 pour le premier 4 , et 7 pour le deuxième 4
    comment faire .??
    merci d'avance

  2. #2
    Membre chevronné
    Avatar de professeur shadoko
    Homme Profil pro
    retraité nostalgique Java SE
    Inscrit en
    Juillet 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : retraité nostalgique Java SE

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 257
    Points : 1 855
    Points
    1 855
    Par défaut
    méthode simple: le faire soi-même
    méthode "bulldozer" : utiliser un TreeSet ?
    J'ai des principes: je peux toujours trouver une bonne raison pour les contredire .... mais j'ai des principes!
    (mon excellent bouquin sur Java : https://eska-publishing.com/fr/livre...822407076.html)

  3. #3
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    La méthode objet: fait un objet encapsulant la valeur et son index, créer une Liste de ces objets, trier la liste avec un comparator, récupérer les index dans le tableau trié:

    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
    public class Main {
     
    	public static class MonType implements Comparable<MonType>{
    		   public int index;
    		   public int valeur;
    		   public MonType(int index, int valeur){
    			   this.index=index;
    			   this.valeur=valeur;
    		   }
    		public int compareTo(MonType o) {
    			return valeur - o.valeur ;
    		}		   
    	}
    	public static void main(String[] argv){
    		int[] elements = new int[]{ 5, 6, 8, 4, 15, 11, 2, 4};
    		int[] result = new int[elements.length];
    		List<MonType> liste = new ArrayList<MonType>();
    		for (int valeur : elements)
    			liste.add(new MonType(liste.size(), valeur));
    		Collections.sort(liste);
    		int i =0;
    		for (MonType t : liste)
    			result[i++] = t.index;
    		System.out.println(Arrays.toString(elements));
    		System.out.println(Arrays.toString(result));
    	}
    }

  4. #4
    Membre régulier
    Profil pro
    Doctorant
    Inscrit en
    Février 2011
    Messages
    258
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2011
    Messages : 258
    Points : 88
    Points
    88
    Par défaut
    merci ça marche like a boss
    mais s.v.p est ce que vous pouvez m'expliquer ce que fait :
    public int compareTo(MonType o) {
    return valeur - o.valeur ;
    }
    merci encore

  5. #5
    Membre expérimenté
    Avatar de yotta
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Septembre 2006
    Messages
    1 088
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 088
    Points : 1 540
    Points
    1 540
    Par défaut
    Je me permettrai de répondre.
    Lorsque l'on veut réaliser une comparaison, l'opération mathématique qui correspond est la soustraction. En réalisant une soustraction, le résultat, quel qu'il soit nous permet de savoir si les termes sont égaux, et s'ils sont différents, quel est le plus grand des deux, le tout en une seule opération.
    L'idée de la méthode compareTo(monType o) c'est que si la "valeur" de l'objet o est égale à la valeur de l'objet comparé, les soustraire renvoi 0. S'ils sont différents, une valeur positive impliquera que la valeur de l'objet comparé est plus grande que celle de l'objet o, et si elle est négative, c'est l'inverse.
    Une comparaison parfaite.
    Une technologie n'est récalcitrante que par ce qu'on ne la connait et/ou comprend pas, rarement par ce qu'elle est mal faite.
    Et pour cesser de subir une technologie récalcitrante, n'hésitez surtout pas à visiter les Guides/Faq du site !

    Voici une liste non exhaustive des tutoriels qui me sont le plus familiers :
    Tout sur Java, du débutant au pro : https://java.developpez.com/cours/
    Tout sur les réseaux : https://reseau.developpez.com/cours/
    Tout sur les systèmes d'exploitation : https://systeme.developpez.com/cours/
    Tout sur le matériel : https://hardware.developpez.com/cours/

  6. #6
    Membre régulier
    Profil pro
    Doctorant
    Inscrit en
    Février 2011
    Messages
    258
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2011
    Messages : 258
    Points : 88
    Points
    88
    Par défaut
    Citation Envoyé par pursang Voir le message
    Je me permettrai de répondre.
    Lorsque l'on veut réaliser une comparaison, l'opération mathématique qui correspond est la soustraction. En réalisant une soustraction, le résultat, quel qu'il soit nous permet de savoir si les termes sont égaux, et s'ils sont différents, quel est le plus grand des deux, le tout en une seule opération.
    L'idée de la méthode compareTo(monType o) c'est que si la "valeur" de l'objet o est égale à la valeur de l'objet comparé, les soustraire renvoi 0. S'ils sont différents, une valeur positive impliquera que la valeur de l'objet comparé est plus grande que celle de l'objet o, et si elle est négative, c'est l'inverse.
    Une comparaison parfaite.
    merci pour l'explication
    mais ce que je n'ai pas compris c'est qu'on a pas utilisé cette méthode dans le code après ?!

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2013
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2013
    Messages : 7
    Points : 12
    Points
    12
    Par défaut
    C'est l'appel à qui appel un algorithme de tri qui lui même utilise la methode afin de pouvoir comparer les différents éléments du tableau.

  8. #8
    Membre régulier
    Profil pro
    Doctorant
    Inscrit en
    Février 2011
    Messages
    258
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2011
    Messages : 258
    Points : 88
    Points
    88
    Par défaut
    ça marche ou je peux trouver la touche résoulu

Discussions similaires

  1. problème avec indexOf ds ArrayList
    Par chadnour dans le forum Collection et Stream
    Réponses: 2
    Dernier message: 24/12/2007, 15h10
  2. Problème avec indexOf()
    Par finalfx dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 24/11/2006, 13h14
  3. Problème avec le type 'Corba::Any_out'
    Par Steven dans le forum CORBA
    Réponses: 2
    Dernier message: 14/07/2002, 18h48
  4. Problème avec la mémoire virtuelle
    Par Anonymous dans le forum CORBA
    Réponses: 13
    Dernier message: 16/04/2002, 16h10

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