【发布时间】:2023-07-17 14:02:02
【问题描述】:
我正在尝试按元素的频率对 NumPy 数组进行排序。例如,如果有一个数组 [3,4,5,1,2,4,1,1,2,4],输出将是另一个 NumPy,从最常见到最不常见的元素(无重复)排序。所以解决方案是[4,1,2,3,5]。如果两个元素的出现次数相同,则最先出现的元素在输出中最先出现。我试过这样做,但我似乎无法得到一个实用的答案。到目前为止,这是我的代码:
temp1 = problems[j]
indexes = np.unique(temp1, return_index = True)[1]
temp2 = temp1[np.sort(indexes)]
temp3 = np.unique(temp1, return_counts = True)[1]
temp4 = np.argsort(temp3)[::-1] + 1
其中问题[j] 是一个 NumPy 数组,如 [3,4,5,1,2,4,1,1,2,4]。 temp4 到目前为止返回 [4,1,2,5,3] 但它不正确,因为当两个元素具有相同的出现次数时它无法处理。
【问题讨论】:
-
Python argsort 不稳定,除非您选择其他排序方法。
标签: python arrays sorting numpy