Spécifications
- Vous disposez d'un espace 3D cubique
x,y,z
d'S
unités de taille entières, telles que0 <= x,y,z <= S
. - Vous obtenez de méthodes d'entrée par défaut un tableau de points
P
représentés commex,y,z
coordonnées entières, dans tout format raisonnable que vous le souhaitez, par exemple:[x1,y1,z1],[x2,y2,z2],[x3,y3,z3] ... [xn,yn,zn]
. - Toutes les
P
valeurs seront dans ledit espace 3D cubique ci-dessus, comme0 <= x,y,z <= S
. - Le nombre total possible de
P
sera .1 <= P <= S3
- Vous obtenez également en entrée les
x,y,z
coordonnées entières du point de baseB
et la taille du cube 3DS
.
Tâche
Votre objectif est de sortir, dans votre format préféré, les points P
triés par la distance linéaire (euclidienne) du point de base B
.
Règles
- Si vous trouvez plusieurs points
P
équidistants,B
vous devez sortir tous les équidistantsP
dans votre ordre préféré. - Il est possible qu'un point
P
coïncide avecB
, de sorte que leur distance soit0
, vous devez sortir ce point. - C'est un défi de code-golf , donc le code le plus court l'emporte.
- Les failles standard sont interdites.
- Les explications du code sont appréciées.
Cas de test
Input:
S (size), [B (base point x,y,z)], [P1 (x,y,z)], [P2], [P3], [P4], [P5], [...], [Pn]
10, [5,5,5], [0,0,0], [10,10,10], [2,0,8], [10,3,1], [4,4,5], [5,5,5], [5,5,4]
Output:
[5,5,5], [5,5,4], [4,4,5], [2,0,8], [10,3,1], [0,0,0], [10,10,10]
- - -
Input:
5, [2, 3, 3], [3, 0, 4], [5, 0, 3], [0, 2, 4], [0, 3, 5], [4, 2, 1], [2, 2, 2], [3, 1, 2], [3, 1, 0], [1, 3, 2], [2, 3, 1], [3, 1, 5], [4, 0, 0], [4, 3, 1], [0, 5, 5], [1, 5, 1], [3, 1, 4], [2, 2, 2], [0, 2, 5], [3, 3, 5], [3, 3, 0], [5, 4, 5], [4, 1, 3], [5, 1, 1], [3, 5, 3], [1, 5, 3], [0, 5, 2], [4, 3, 3], [2, 1, 1], [3, 3, 0], [5, 0, 4], [1, 5, 2], [4, 2, 3], [4, 2, 1], [2, 5, 5], [3, 4, 0], [3, 0, 2], [2, 3, 2], [3, 5, 1], [5, 1, 0], [2, 4, 3], [1, 0, 5], [0, 2, 5], [3, 4, 4], [2, 4, 0], [0, 1, 5], [0, 5, 4], [1, 5, 1], [2, 1, 0], [1, 3, 4], [2, 2, 2], [4, 2, 4], [5, 5, 4], [4, 4, 0], [0, 4, 1], [2, 0, 3], [3, 1, 5], [4, 4, 0], [2, 5, 1], [1, 2, 4], [4, 3, 1], [0, 2, 4], [4, 5, 2], [2, 0, 1], [0, 0, 2], [4, 1, 0], [5, 4, 3], [2, 5, 2], [5, 4, 4], [4, 4, 3], [5, 5, 1], [4, 0, 2], [1, 3, 5], [4, 2, 0], [0, 3, 1], [2, 2, 0], [0, 4, 5], [3, 2, 0], [0, 2, 1], [1, 2, 2], [2, 5, 3], [5, 5, 2], [5, 2, 4], [4, 5, 5], [2, 1, 2], [5, 4, 3], [4, 5, 4], [2, 3, 1], [4, 4, 4], [3, 0, 0], [2, 4, 5], [4, 3, 3], [3, 5, 3], [4, 0, 0], [1, 1, 1], [3, 1, 3], [2, 5, 5], [0, 0, 5], [2, 0, 2], [1, 0, 3], [3, 1, 4], [1, 2, 5], [4, 1, 3], [1, 4, 5], [3, 1, 4], [3, 5, 1], [5, 1, 4], [1, 0, 4], [2, 2, 0], [5, 2, 1], [0, 5, 3], [2, 1, 1], [0, 3, 0], [4, 5, 5], [3, 4, 2], [5, 3, 3], [3, 1, 1], [4, 0, 1], [5, 0, 5], [5, 0, 4], [1, 4, 3], [5, 4, 2], [5, 4, 0], [5, 1, 0], [0, 0, 1], [5, 3, 0]
Output:
[2, 4, 3], [2, 3, 2], [1, 3, 4], [1, 3, 2], [2, 2, 2], [1, 4, 3], [2, 2, 2], [2, 2, 2], [1, 2, 2], [3, 4, 2], [1, 2, 4], [3, 4, 4], [2, 5, 3], [4, 3, 3], [2, 3, 1], [4, 3, 3], [2, 3, 1], [1, 3, 5], [4, 4, 3], [2, 5, 2], [3, 1, 3], [1, 5, 3], [4, 2, 3], [2, 1, 2], [3, 5, 3], [2, 4, 5], [3, 3, 5], [3, 5, 3], [3, 1, 4], [0, 2, 4], [0, 2, 4], [1, 2, 5], [3, 1, 2], [3, 1, 4], [3, 1, 4], [4, 2, 4], [1, 4, 5], [4, 4, 4], [1, 5, 2], [4, 3, 1], [0, 5, 3], [2, 1, 1], [4, 1, 3], [4, 3, 1], [2, 5, 5], [0, 3, 5], [4, 1, 3], [2, 5, 1], [2, 1, 1], [0, 3, 1], [2, 5, 5], [1, 1, 1], [0, 4, 5], [4, 5, 4], [4, 5, 2], [0, 2, 1], [1, 5, 1], [5, 3, 3], [0, 5, 2], [3, 5, 1], [3, 5, 1], [0, 2, 5], [1, 5, 1], [4, 2, 1], [3, 1, 5], [3, 1, 1], [0, 2, 5], [4, 2, 1], [0, 5, 4], [0, 4, 1], [2, 0, 3], [3, 1, 5], [2, 4, 0], [2, 2, 0], [2, 0, 2], [3, 3, 0], [3, 3, 0], [5, 4, 3], [1, 0, 3], [5, 4, 3], [2, 2, 0], [3, 0, 2], [5, 4, 4], [5, 4, 2], [1, 0, 4], [3, 0, 4], [5, 2, 4], [3, 2, 0], [3, 4, 0], [0, 1, 5], [0, 5, 5], [4, 5, 5], [4, 5, 5], [0, 3, 0], [2, 0, 1], [2, 1, 0], [4, 4, 0], [5, 1, 4], [5, 5, 4], [5, 2, 1], [3, 1, 0], [5, 4, 5], [4, 4, 0], [1, 0, 5], [4, 2, 0], [0, 0, 2], [4, 0, 2], [5, 5, 2], [4, 1, 0], [5, 5, 1], [0, 0, 1], [5, 1, 1], [4, 0, 1], [0, 0, 5], [5, 0, 3], [5, 3, 0], [5, 4, 0], [3, 0, 0], [5, 0, 4], [5, 0, 4], [5, 1, 0], [4, 0, 0], [4, 0, 0], [5, 0, 5], [5, 1, 0]
- - -
Input:
10, [1, 9, 4], [4, 6, 2], [7, 5, 3], [10, 5, 2], [9, 8, 9], [10, 5, 10], [1, 5, 4], [8, 1, 1], [8, 6, 9], [10, 4, 1], [3, 4, 10], [4, 7, 0], [7, 10, 9], [5, 7, 3], [6, 7, 9], [5, 1, 4], [4, 3, 8], [4, 4, 9], [6, 9, 3], [8, 2, 6], [3, 5, 1], [0, 9, 0], [8, 4, 3], [0, 1, 1], [6, 7, 6], [4, 6, 10], [3, 9, 10], [8, 3, 1], [10, 1, 1], [9, 10, 6], [2, 3, 9], [10, 5, 0], [3, 2, 1], [10, 2, 7], [8, 4, 9], [5, 2, 4], [0, 8, 9], [10, 1, 6], [0, 8, 10], [5, 10, 1], [7, 4, 5], [4, 5, 2], [0, 2, 0], [8, 3, 3], [6, 6, 6], [3, 0, 2], [0, 1, 1], [10, 10, 8], [6, 2, 8], [8, 8, 6], [5, 4, 7], [10, 7, 4], [0, 9, 2], [1, 6, 6], [8, 5, 9], [3, 7, 4], [5, 6, 6], [3, 1, 1], [10, 4, 5], [1, 5, 7], [8, 6, 6], [4, 3, 7], [2, 1, 0], [6, 4, 2], [0, 7, 8], [8, 3, 6], [9, 2, 0], [1, 3, 8], [4, 4, 6], [5, 8, 9], [9, 4, 4], [0, 7, 3], [8, 3, 4], [6, 7, 9], [8, 7, 0], [0, 7, 7], [8, 10, 10], [10, 2, 5], [6, 9, 5], [6, 2, 7], [0, 9, 6], [1, 4, 1], [4, 3, 1], [5, 7, 3], [9, 6, 8], [4, 1, 7], [4, 0, 8], [3, 4, 7], [2, 3, 6], [0, 0, 7], [5, 3, 6], [7, 3, 4], [6, 7, 8], [3, 7, 9], [1, 9, 10], [2, 1, 2], [2, 8, 2], [0, 3, 0], [1, 1, 9], [3, 5, 2], [10, 5, 3], [5, 2, 9], [6, 9, 0], [9, 5, 0], [7, 1, 10], [3, 3, 8], [2, 5, 1], [3, 10, 10], [6, 2, 2], [10, 7, 2], [4, 3, 1], [4, 2, 1], [4, 2, 8], [6, 8, 5], [3, 10, 0], [1, 1, 7], [6, 9, 6], [6, 2, 4], [5, 5, 7], [5, 4, 5], [9, 8, 1], [9, 8, 1], [0, 10, 6], [1, 1, 9], [3, 8, 8], [3, 1, 5], [5, 7, 4], [4, 3, 6], [5, 4, 7], [6, 0, 8], [7, 8, 1], [9, 8, 4], [2, 10, 0], [3, 4, 5], [9, 3, 10], [7, 4, 1], [2, 1, 9], [10, 8, 1], [10, 3, 7], [2, 0, 6], [3, 8, 4], [10, 0, 2], [9, 9, 10], [8, 9, 5], [4, 10, 2], [8, 3, 4], [4, 2, 10], [9, 1, 6], [6, 1, 3], [4, 1, 3], [2, 9, 0], [5, 6, 5], [8, 8, 3], [5, 5, 0], [7, 6, 9], [1, 1, 5], [3, 0, 4], [1, 10, 6], [8, 0, 2], [0, 7, 3], [8, 9, 8], [2, 1, 8], [3, 1, 10], [4, 5, 9], [7, 6, 10], [3, 6, 10], [5, 9, 8], [9, 3, 3], [2, 2, 3], [9, 9, 0], [7, 2, 2], [0, 0, 9], [8, 7, 4], [9, 2, 9], [0, 6, 4], [9, 4, 3], [10, 1, 3], [5, 9, 10], [5, 10, 6], [6, 3, 10],
Output:
[1, 10, 6], [3, 8, 4], [0, 9, 6], [0, 9, 2], [2, 8, 2], [0, 7, 3], [0, 7, 3], [0, 10, 6], [3, 7, 4], [0, 6, 4], [1, 6, 6], [0, 7, 7], [4, 10, 2], [1, 5, 4], [0, 9, 0], [2, 9, 0], [2, 10, 0], [5, 7, 4], [5, 7, 3], [5, 10, 6], [5, 7, 3], [0, 7, 8], [3, 10, 0], [3, 8, 8], [4, 6, 2], [3, 5, 2], [1, 5, 7], [5, 10, 1], [6, 9, 3], [6, 9, 5], [5, 6, 5], [2, 5, 1], [0, 8, 9], [6, 8, 5], [5, 6, 6], [6, 9, 6], [4, 5, 2], [4, 7, 0], [3, 5, 1], [3, 4, 5], [5, 9, 8], [6, 7, 6], [3, 7, 9], [1, 4, 1], [1, 9, 10], [4, 4, 6], [0, 8, 10], [6, 6, 6], [3, 4, 7], [3, 9, 10], [5, 5, 7], [3, 10, 10], [2, 3, 6], [6, 9, 0], [5, 8, 9], [5, 4, 5], [6, 7, 8], [7, 8, 1], [5, 5, 0], [4, 3, 6], [3, 6, 10], [8, 9, 5], [5, 4, 7], [4, 5, 9], [5, 4, 7], [2, 2, 3], [8, 8, 3], [1, 3, 8], [5, 9, 10], [0, 3, 0], [7, 5, 3], [8, 7, 4], [4, 3, 1], [8, 8, 6], [6, 4, 2], [4, 3, 7], [6, 7, 9], [4, 6, 10], [4, 3, 1], [6, 7, 9], [3, 3, 8], [5, 3, 6], [4, 4, 9], [4, 3, 8], [8, 6, 6], [3, 2, 1], [7, 4, 5], [7, 10, 9], [2, 3, 9], [5, 2, 4], [1, 1, 5], [3, 4, 10], [8, 9, 8], [9, 8, 4], [0, 2, 0], [4, 2, 1], [3, 1, 5], [2, 1, 2], [8, 7, 0], [9, 10, 6], [7, 4, 1], [7, 6, 9], [7, 3, 4], [1, 1, 7], [0, 1, 1], [4, 2, 8], [9, 8, 1], [0, 1, 1], [4, 1, 3], [6, 2, 4], [9, 8, 1], [8, 4, 3], [3, 1, 1], [6, 2, 2], [5, 1, 4], [9, 9, 0], [7, 6, 10], [2, 1, 0], [2, 1, 8], [4, 1, 7], [8, 6, 9], [6, 2, 7], [8, 3, 4], [8, 3, 4], [10, 7, 4], [3, 0, 4], [8, 3, 3], [8, 10, 10], [2, 0, 6], [9, 6, 8], [10, 7, 2], [1, 1, 9], [8, 3, 6], [1, 1, 9], [7, 2, 2], [3, 0, 2], [9, 4, 4], [8, 5, 9], [2, 1, 9], [6, 1, 3], [6, 2, 8], [5, 2, 9], [9, 4, 3], [9, 8, 9], [0, 0, 7], [10, 8, 1], [4, 2, 10], [8, 3, 1], [9, 5, 0], [6, 3, 10], [10, 10, 8], [10, 5, 3], [8, 4, 9], [9, 9, 10], [10, 5, 2], [9, 3, 3], [8, 2, 6], [3, 1, 10], [4, 0, 8], [0, 0, 9], [10, 4, 5], [10, 5, 0], [10, 4, 1], [8, 1, 1], [6, 0, 8], [10, 3, 7], [9, 2, 0], [10, 2, 5], [9, 1, 6], [10, 5, 10], [8, 0, 2], [9, 3, 10], [7, 1, 10], [9, 2, 9], [10, 2, 7], [10, 1, 3], [10, 1, 6], [10, 1, 1], [10, 0, 2]
- - -
Input:
10000, [8452, 3160, 6109], [7172, 5052, 4795], [9789, 4033, 2952], [8242, 213, 3835], [177, 7083, 908], [3788, 3129, 3018], [9060, 464, 2701], [6537, 8698, 291], [9048, 3860, 6099], [4600, 2696, 4854], [2319, 3278, 9825]
Output:
[9048, 3860, 6099], [7172, 5052, 4795], [9789, 4033, 2952], [8242, 213, 3835], [4600, 2696, 4854], [9060, 464, 2701], [3788, 3129, 3018], [2319, 3278, 9825], [6537, 8698, 291], [177, 7083, 908]
S
comme paramètre?Réponses:
05AB1E , 4 octets
Essayez-le en ligne!
Explication
la source
n
?JavaScript (ES6), 71 octets
la source
g
intérieursort
.Haskell ,
5452 octetsEssayez-le en ligne!
Je n'ai pas besoin de la taille de l'espace.
sum.map(^2).zipWith(-)o
calcule la distance d'un point ào
:(xo-xp)^2+(yo-yp)^2+(zo-zp)^2
. Les points sont simplement triés sur la distance ào
.EDIT : "si vous n'en avez pas besoin, ne le prenez pas" a sauvé 2 octets.
la source
Python 3 ,
6864 octets-4 octets grâce à @Ramillies
Essayez-le en ligne!
la source
R ,
5640 octets-16 octets grâce à Flodel pour avoir suggéré un format d'entrée différent
Essayez-le en ligne!
Prend
P
comme3xn
matrice de points, c'est-à-dire que chaque colonne est un point; la sortie est au même format.Utilisez la fonction d'assistance
g
pour transformer la liste des pointsP
des cas de test au format R approprié.la source
sapply()
parcolSums((t(P)-B)^2)
, où l'entréeP
serait une matrice?P
comme3xn
matrice et juste faire à lacolSums((P-B)^2)
place!Mathematica, 24 octets
Prend la saisie dans le format
f[B][P]
.Nous devons utiliser 4 octets
x
pour créer la fonction imbriquée. La priorité de
(\[Function]
) et//
fonctionne bien pour que l'expression soit équivalente à ceci:Nous en avons besoin
N
car par défaut, Mathematica trie par structure d'expression plutôt que par valeur:la source
C # (.NET Core) ,
685753 +2318 octets-11 octets grâce à Emigna
Le nombre d'octets comprend également
Essayez-le en ligne!
Les points sont traités comme des collections d'entiers. Explication:
la source
JavaScript (ES6),
7271 octetsCelui-ci n'est pas plus court que la réponse de Neil , mais j'ai pensé que je le
Math.hypot()
publierais quand même pour démontrer l'utilisation de , qui a été introduit dans ES6.Prend l'entrée dans la syntaxe de curry
(p)(a)
, où p = [x, y, z] est le point de base et a est le tableau des autres points.Afficher l'extrait de code
la source
k , 14 octets
Essayez-le en ligne!
En outre, cela fonctionne pour n dimensions et n'est pas limité à 3.
la source
Japt ,
109 octets-1 octet grâce à @Shaggy
Prend les points comme un tableau de tableaux à trois éléments et le point de base un tableau unique, dans cet ordre. Ne prend pas l'argument de taille.
Essayez-le en ligne! ou exécutez l' énorme cas de test avec
-R
pour en produire unx,y,z
par ligne.Explication
la source
í
pouvais prendre ses arguments à l'envers, c'est plutôt sympa. Moi aussi, je pense que cela devrait fonctionner; Je vais exécuter certains des autres cas de test et les modifier lorsque je serai de retour sur un ordinateur.-
oun
fonctionnerait également à la place dea
.MATL , 7 octets
Les entrées sont: matrice à 3 colonnes avec des points comme lignes et vecteur à 3 colonnes avec point de base.
Essayez-le sur MATL Online!
Explication
la source
Gelée , 5 octets
1 octet enregistré, grâce à Leaky Nun .
Essayez-le en ligne!
Explication
la source
ạS¥Þ
(je n'ai pas remarqué votre réponse avant de poster la mienne).ạ²SµÞ
Perl 6 , 35 octets (33 caractères)
Essayez-le en ligne!
Explication: Cela prend une liste avec les coordonnées du point de base (appelé
@b
), puis une liste des listes avec les coordonnées des autres points (appelé@p
). Dans un bloc, vous pouvez les utiliser à la volée en utilisant le^
symbole. Chacune des^
variables 'd correspond à un argument. (Ils sont triés par ordre alphabétique, tout@^b
comme le 1er argument et@^p
le 2e.) Après une utilisation de ce symbole, vous pouvez utiliser la variable normalement.La déclaration
@^b
est là juste pour dire que le bloc prendra l'argument du point de base, qui n'est utilisé qu'à l'intérieur du bloc de tri. (Sinon, cela ferait référence à l'argument du bloc de tri.) La méthode.sort
peut prendre un argument. Si c'est un bloc prenant 1 argument (comme ici), le tableau est trié selon les valeurs de cette fonction. Le bloc lui-même prend chaque point à son tour et le zippe avec moins (Z-
) avec les coordonnées du point de base. Ensuite, nous cadrons tous les éléments de la liste avec»²
et les additionnons à l'aide[+]
.En prime, cela fonctionnera également avec les coordonnées flottantes et dans toutes les dimensions (tant que vous fournissez évidemment le même nombre de coordonnées pour tous les points, cela fait la bonne chose).
Ce n'est plus valable. Je le laisse ici juste pour le plaisir.
Perl 6 , 24 octets - seulement une blague!
Essayez-le en ligne!
Étant donné que l'OP ne précise pas quelle métrique doit être utilisée, cette soumission choisit d'utiliser la métrique discrète. Dans cette métrique, la distance entre deux points est 0 s'ils sont identiques et 1 s'ils ne le sont pas. Il est facile de vérifier qu'il s'agit bien d'une métrique (si ρ (A, B) est la distance de A à B, il faut que 1) ρ (A, B) = 0 ssi A = B, 2) ρ (A, B ) = ρ (B, A), 3) ρ (A, B) + ρ (B, C) ≥ ρ (A, C) ("inégalité triangulaire")).
Il pourrait probablement être beaucoup plus joué au golf, mais je ne le pense pas sérieusement.
la source
<5 5 5>,(<5 5 10>,<6 5 5>)
. Les listes ne trient pas par leur somme, mais par comparaison élément par élément. Vous avez besoin d'unsum
endroit.Kotlin 1.1, 58 octets
Embellie
Tester
la source
Java 8,
194 + 31214169163123112 112106 + 19109103 octetsEssayez-le en ligne!
la source
base=[2,3,3], points=[4,3,3],[1,3,4]
. Votre résultat est[4,3,3], [1,3,4]
, tandis que le résultat correct est[1,3,4],[4,3,3]
.b->l->{l.sort(java.util.Comparator.comparing(p->{int d=0,i=3;for(;i-->0;)d+=(b[i]-p[i])*(b[i]-p[i]);return d;}));}
(114 octets), en supposant unList<int[]>
paramètre as au lieu deint[][]
.pow
ça marche+=
sans casting, pas dans la plupart des autres cas. Bon à savoir!B->P->P.sort(java.util.Comparator.comparing(p->{int d=0,i=0;while(i<3)d+=(d=p[i]-B[i++])*d;return d;}))
Pyth, 6 octets
Essayez-le en ligne: Démonstration
Explication:
la source
Bad Request: Request Line is too large (7005 > 4094)
. Vous devez réduire la taille de votre suite de tests afin de l'adapter à la taille de lien maximale.Perl 5 , 90 octets
Essayez-le en ligne!
L'entrée est une liste de points séparés par des sauts de ligne, le premier étant le point de base et le dernier ayant un saut de ligne final. Les crochets (
[]
) autour des coordonnées sont facultatifs.la source