0
votes

Numéros de tri de la chaîne dactylographiée dans un Treeemap

J'ai un ensemble de données qui avant de tracer, je voulais réorganiser.

Les données consistent en un tas de nombres répétés et de ceux que vous calculez la frécution. Ensuite, dans une autre fonction, j'essaie de réorganiser les données transformées (réogniser les frécuances) dans l'ordre de chiffre ascendant. P>

Java a de nombreux outils pour cela, mais je n'ai pas été inflexible en raison de la clé de la clé. Traité comme une chaîne (je sais que c'est bizarre, mais je ne peux pas le changer ...) p>

Cette fonction obtient toutes les données dans une liste, des données brutes qui doivent être traitées. il vient "commandé ASC" de la requête SQL. strong> p> xxx pré>

mais une fois traité ... La clé est le numéro précédent répété dans le Liste et la valeur est le nombre de répétitions -> Frécuence. P>

[46, 46, 46, 46, 46, 47, 47, 47, 47, 47, 47, 47, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 48, 49, 49, 49, 49, 49, 50, 50, 50, 50, 50, 50, 50, 50, 50, 51, 51, 51, 51, 51, 51, 51, 52, 52, 52, 52, 52, 52, 52, 53, 53, 53, 53, 53, 53, 53, 53, 53, 54, 54, 54, 54, 54, 54, 55, 55, 56, 56, 56, 56, 56, 57, 57, 57, 57, 57, 57, 57, 58, 58, 58, 58, 58, 58, 58, 59, 59, 59, 59, 59, 59, 59, 59, 59, 60, 60, 60, 60, 60, 60, 60, 60, 61, 61, 61, 61, 61, 61, 61, 61, 61, 61, 62, 62, 62, 62, 62, 62, 63, 63, 63, 63, 63, 63, 63, 63, 63, 64, 64, 64, 64, 64, 64, 64, 64, 64, 65, 65, 65, 65, 65, 65, 65, 66, 66, 67, 67, 67, 67, 67, 67, 67, 67, 68, 68, 68, 68, 68, 69, 69, 69, 69, 69, 69, 70, 70, 70, 70, 70, 70, 70, 71, 71, 71, 71, 71, 71, 71, 72, 72, 72, 72, 73, 73, 73, 73, 73, 73, 73, 73, 73, 73, 73, 73, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 75, 75, 75, 75, 75, 75, 75, 75, 75, 75, 76, 76, 76, 76, 76, 76, 76, 77, 77, 77, 77, 77, 77, 78, 78, 78, 78, 78, 78, 79, 79, 79, 79, 79, 79, 80, 80, 80, 80, 80, 80, 80, 80, 80, 80, 81, 81, 81, 82, 82, 82, 82, 82, 82, 82, 83, 83, 83, 83, 83, 83, 84, 84, 84, 84, 84, 84, 84, 84, 84, 84, 84, 84, 84, 85, 85, 85, 85, 85, 85, 85, 85, 85, 85, 85, 85, 85, 85, 85, 85, 85, 86, 86, 86, 86, 86, 87, 87, 87, 87, 87, 87, 88, 88, 88, 88, 89, 89, 89, 89, 89, 89, 90, 90, 90, 90, 90, 91, 91, 91, 91, 91, 91, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 93, 93, 93, 93, 93, 93, 93, 93, 94, 94, 94, 94, 95, 95, 96, 96, 97, 97, 97, 97, 98, 98, 98, 98, 98, 98, 98, 98, 99, 99, 99, 99, 99, 99, 99, 99, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 101, 101, 101, 101, 101, 101, 101, 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, 103, 103, 103, 103, 103, 103, 103, 103, 103, 104, 104, 104, 104, 104, 104, 105, 105, 105, 105, 105, 105, 106, 106, 106, 106, 106, 106, 107, 107, 107, 107, 107, 107, 107, 107, 107, 107, 108, 108, 108, 108, 108, 109, 109, 109, 109, 109, 109, 109, 110, 110, 110, 110, 110, 110, 110, 110, 110, 111, 111, 111, 111, 111, 111, 111, 112, 112, 112, 112, 112, 112, 112, 112, 112, 112, 112, 112, 112, 113, 113, 113, 113, 113, 113, 113, 113, 114, 114, 114, 114, 114, 114, 114, 114, 114, 114, 115, 115, 115, 115, 115, 115, 115, 116, 116, 116, 116, 117, 117, 117, 117, 117, 118, 118, 118, 118, 118, 118, 118, 118, 119, 119, 119, 119, 119, 119, 120, 120, 120, 120, 120, 120, 120, 120, 120, 121, 121, 121, 121, 121, 121, 121, 121, 122, 122, 122, 122, 122, 122, 122, 122, 122, 122, 122, 123, 123, 123, 123, 123, 123, 123, 124, 124, 124, 124, 125, 125, 125, 125, 125, 125, 125, 126, 126, 126, 126, 126, 126, 126, 126, 126, 127, 127, 127, 127, 127, 128, 128, 128, 128, 128, 128, 128, 129, 129, 129, 129, 129, 129, 129, 130, 130, 130, 130, 130, 130, 131, 131, 131, 131, 131, 132, 132, 132, 132, 132, 132, 132, 132, 133, 133, 133, 133, 133, 134, 134, 134, 134, 134, 135, 135, 135, 135, 135, 135, 135, 135, 135, 135, 136, 136, 136, 136, 136, 136, 136, 136, 136, 137, 137, 137, 137, 137, 137, 137, 137, 137, 138, 138, 138, 138, 138, 138, 139, 139, 139, 139, 139, 139, 139, 139, 139, 139, 139, 140, 140, 140, 140, 140, 141, 141, 141, 141, 141, 141, 141, 142, 142, 142, 142, 142, 142, 142, 143, 143, 143, 143, 143, 143, 143, 144, 144, 144, 144, 144, 144, 144, 144, 145, 145, 145, 145, 145, 145, 145, 146, 146, 146, 146, 146, 147, 147, 147, 147, 147, 147, 147, 147, 147, 148, 148, 148, 148, 148, 148, 148, 149, 149, 149, 149, 149, 149, 150, 150, 150, 150, 150, 150, 150, 150, 151, 151, 151, 151, 151, 151, 151, 152, 152, 152, 152, 152, 152, 152, 152, 152, 153, 153, 153, 153, 153, 153, 153, 153, 153, 154, 154, 154, 154, 154, 154, 154, 155, 155, 155, 155, 155, 155, 156, 156, 156, 156, 157, 157, 157, 157, 157, 157, 158, 158, 158, 158, 158, 158, 159, 159, 159, 159, 159, 159, 160, 160, 160, 160, 160, 160, 161, 161, 161, 161, 161, 161, 161, 161, 161, 162, 162, 162, 162, 162, 163, 163, 163, 163, 163, 163, 163, 164, 164, 164, 164, 165, 165, 165, 165, 165, 166, 166, 166, 166, 166, 167, 167, 167, 167, 167, 167, 167, 168, 168, 168, 168, 169, 169, 169, 169, 169, 169, 170, 170, 170, 170, 171, 171, 171, 171, 171, 171, 171, 171, 172, 172, 172, 172, 172, 172, 172, 172, 173, 173, 173, 173, 173, 173, 173, 174, 174, 174, 174, 174, 174, 175, 175, 175, 175, 175, 175, 176, 176, 176, 176, 176, 176, 176, 176, 176, 176, 177, 177, 177, 177, 177, 177, 178, 178, 178, 178, 178, 178, 178, 178, 178, 178, 179, 179, 179, 179, 179, 179, 179, 179, 179, 179, 179, 179, 179, 180, 180, 180, 180, 180, 180, 180, 181, 181, 181, 181, 181, 181, 181, 181, 181, 181, 182, 182, 182, 182, 182, 182, 183, 183, 183, 183, 183, 184, 184, 184, 184, 184, 184, 184, 184, 185, 185, 185, 185, 185, 185, 185, 185, 185, 185]


0 commentaires

3 Réponses :


2
votes

La carte Java Comparaisonbyey () Commande les entrées par leur commande naturelle. Pour les chaînes, que commande est lexicographique , ce qui signifie que les chaînes sont comparées de caractère par caractère; String A vient avant la chaîne B Si le premier caractère non-correspondant vient avant le caractère positionné de la même manière dans la chaîne B ou, si tous les caractères correspondent, si A est inférieur à B.

même si 46 vient avant 100 , "46" vient après "100" parce que '4' vient après '1' .

Vous avez deux options ici:

  1. Vous pouvez préparer un "0" sur tous les numéros à deux chiffres. Je recommande de ce dire car cela nécessite une logique supplémentaire si vous avez finalement besoin de touches à 4 chiffres et que la sortie que vous affiche ne correspondra pas aux valeurs réelles enregistrées dans la base de données pouvant causer des bogues (ou une confusion générale) dans la ligne.
  2. Écrivez un comparateur personnalisé qui représente des chaînes de longueur différente ( "" Commandez "). xxx

    et utilisez-le comme xxx


1 commentaires

J'ai essayé d'utiliser mon propre comparateur mais je ne pouvais pas le faire travailler. J'ai testé votre réponse et est valable aussi. Merci!



1
votes

Vous pouvez écrire un comparateur personnalisé pour vérifier si la valeur est la chaîne ou l'int et comparez en conséquence.

Le code ci-dessous fonctionne même si vous avez des valeurs de chaîne au lieu d'entiers à l'intérieur de votre clé. ( {1 = 3, 12 = 1, a = 1, kishore = 1, 46 = 2, 48 = 1} ) xxx

si Vous êtes sûr que vos clés sont toujours des entiers stockés sous forme de chaîne, vous pouvez retirer le bloc de capture.


3 commentaires

Formidable! J'apprends actuellement ces collections Java. Merci pour votre temps


Ce comportement de secours pour les exceptions en violation de l'exigence de transitivité des comparateurs. La solution la plus simple n'est pas de mettre en œuvre une manipulation des exceptions que personne n'a demandé. Just comparator.comparingint (E -> INTEGER.PARSINTINT (E.GETKEY ())) ...


@Holger True, d'où la dernière note dans la réponse pour supprimer le bloc de capture. Je n'étais pas sûr si OP signifiait que les clés peuvent contenir des valeurs de chaîne réelles aussi bien ou non ( la clé est une chaîne )



1
votes

Utilisation de comparateur qui convertit la clé en un entier à trier par clé xxx

, si vous souhaitez trier par fréquence xxx

, exemple de tri par clé: xxx


1 commentaires

J'ai essayé de convertir les données avant de faire tout ce travail, mais j'ai testé que les autres jeux de données ne conviennent pas. Ensuite, je suis allé essayer quelque chose comme le vôtre mais je suis trop compliqué pour ce dont j'avais besoin. Super idée de mon ami, même si je me suis perdu avec trop d'expressions de Lambda. Merci pour votre réponse: D