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> 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]
3 Réponses :
La carte Java même si Vous avez deux options ici: p> et utilisez-le comme p> Comparaisonbyey () Code> 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.
46 code > vient avant
100 code>,
"46" code> vient après
"100" code> parce que
'4' code> vient après
'1' code>. P>
"0" code> 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. li>
personnalisé code> qui représente des chaînes de longueur différente ( "" Commandez "). LI>
ol>
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!
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é. ( 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. P> p> {1 = 3, 12 = 1, a = 1, kishore = 1, 46 = 2, 48 = 1} code>) p>
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 ())) CODE> ...
@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 code>)
Utilisation de comparateur qui convertit la clé en un entier à trier par clé , si vous souhaitez trier par , exemple de tri par clé: p> code>
fréquence code> p>
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