Python: сортировка списка и изменение другого

У меня есть два списка: один содержит множество x точек, а другой содержит y точек. Python каким-то образом удается смешивать точки x, или пользователь может. Мне нужно отсортировать их по наименьшему и наивысшему, и переместите y-точки, чтобы следовать за их x корреспондентами. Они находятся в двух отдельных списках.. как мне это сделать?

Ответы

Ответ 1

Вы можете заархивировать списки и отсортировать результат. Сортировка кортежей по умолчанию будет сортироваться по первому члену.

>>> xs = [3,2,1]
>>> ys = [1,2,3]
>>> points = zip(xs,ys)
>>> points
[(3, 1), (2, 2), (1, 3)]
>>> sorted(points)
[(1, 3), (2, 2), (3, 1)]

И затем снова распаковать их:

>>> sorted_points = sorted(points)
>>> new_xs = [point[0] for point in sorted_points]
>>> new_ys = [point[1] for point in sorted_points]
>>> new_xs
[1, 2, 3]
>>> new_ys
[3, 2, 1]

Ответ 2

>>> xs = [5, 2, 1, 4, 6, 3]
>>> ys = [1, 2, 3, 4, 5, 6]
>>> xs, ys = zip(*sorted(zip(xs, ys)))
>>> xs
(1, 2, 3, 4, 5, 6)
>>> ys
(3, 2, 6, 4, 1, 5)

Ответ 3

>>> import numpy

>>> sorted_index = numpy.argsort(xs)
>>> xs = [xs[i] for i in sorted_index]
>>> ys = [ys[i] for i in sorted_index]

если вы можете работать с numpy.array

>>> xs = numpy.array([3,2,1])
>>> xs = numpy.array([1,2,3])
>>> sorted_index = numpy.argsort(xs)
>>> xs = xs[sorted_index]
>>> ys = ys[sorted_index]

Ответ 4

Если x и y предназначены для одной единицы (например, точки), было бы разумнее хранить их как кортежи, а не два отдельных списка.

Независимо от того, что вы должны сделать:

x = [4, 2, 5, 4, 5,…]
y = [4, 5, 2, 3, 1,…]

zipped_list = zip(x,y)
sorted_list = sorted(zipped_list)