深入探索np.argsort的各個細節

一、概述

np.argsort是numpy模塊中的一個函數,可返回一維數組中元素排序後的下標。該函數返回的是排序後各元素相對於原數組的下標值,並且數組元素值不變。

二、基本語法

np.argsort有三個參數:

numpy.argsort(a, axis=-1, kind='quicksort', order=None)

a表示需要排序的數組,axis表示排序的方向(默認-1,即從最後一個維度開始排序),kind表示使用的排序算法(默認是快速排序),order表示按照某一列排序(用於結構體做比較)。

舉個例子:

import numpy as np

a = np.array([3, 1, 4, 2])
idx = np.argsort(a)
print(idx)

輸出結果為:array([1, 3, 0, 2], dtype=int64)

說明原數組中第1個元素(1)排在第一個,第3個元素(2)排在第二個,第0個元素(3)排在第三個,第2個元素(4)排在第四個。

三、多個數組排序

可以使用argsort對多個數組排序,只需將多個數組組合成一個元組,然後將這個元組作為一個參數傳給argsort即可:

import numpy as np

x = np.array([3, 1, 4, 2])
y = np.array([5, 7, 6, 8])
idx = np.argsort((x, y))
print(idx)

輸出結果為:array([1, 3, 0, 2], dtype=int64)

說明兩個數組按照x的排序順序排序,這是它們的聯合排序順序。

四、逆序排序

默認情況下,np.argsort函數執行的是升序排序。如果想按降序排序,在調用np.argsort函數時,可將需要排序的數組加上一個負號,並指定axis參數(不能是None)。

import numpy as np

a = np.array([3, 1, 4, 2])
idx = np.argsort(-a, axis=0)
print(idx)

輸出結果為:array([2, 0, 3, 1], dtype=int64)

說明原數組中第2個元素(4)排在第一個,第0個元素(3)排在第二個,第3個元素(2)排在第三個,第1個元素(1)排在第四個。

五、實戰應用:排序並獲取對應原下標

有時候需要將原數組的下標和按下標排序後的結果一起輸出。這時仍然可以使用np.argsort函數,然後對結果應用相應的矩陣計算即可。

import numpy as np

a = np.array([3, 1, 4, 2])
idx = np.argsort(a)
print(idx)
print(idx.argsort())
print(np.arange(len(idx)))
sort_idx = np.argsort(idx)
print(sort_idx)
print(sort_idx.argsort())

輸出結果為:

[1 3 0 2]
[2 0 3 1]
[0 1 2 3]
[1 3 0 2]
[2 0 3 1]

從輸出結果可以看出,idx.argsort()等同於np.arange(len(idx)),這是因為argsort返回的是排序後原下標的順序,這樣再應用一次argsort就可以得到原下標了,即sort_idx=argsort(argsort(idx)),然後再對sort_idx排序就可以得到最終結果。

六、總結

在numpy中,np.argsort是非常常用的排序函數,掌握該函數的使用方法和注意事項對於numpy編程非常重要。尤其是在需要對多個數組進行排序、降序排序、重組原數組的下標等操作時,np.argsort起到了非常重要的作用。

原創文章,作者:JOUW,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/131412.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
JOUW的頭像JOUW
上一篇 2024-10-03 23:45
下一篇 2024-10-03 23:45

相關推薦

  • int類型變量的細節與注意事項

    本文將從 int 類型變量的定義、聲明、初始化、範圍、運算和類型轉換等方面,對 int 類型變量進行詳細闡述和講解,幫助讀者更好地掌握和應用 int 變量。 一、定義與聲明 int…

    編程 2025-04-29
  • Python中的np.arange函數

    在本篇文章中,我們將着眼於Python中的np.arange函數。我們將從多個方面對這個函數進行全面解析,涵蓋的內容包括介紹、功能、用法、案例以及注意事項等。如果您想深入了解np.…

    編程 2025-04-28
  • 深入解析Vue3 defineExpose

    Vue 3在開發過程中引入了新的API `defineExpose`。在以前的版本中,我們經常使用 `$attrs` 和` $listeners` 實現父組件與子組件之間的通信,但…

    編程 2025-04-25
  • 深入理解byte轉int

    一、字節與比特 在討論byte轉int之前,我們需要了解字節和比特的概念。字節是計算機存儲單位的一種,通常表示8個比特(bit),即1字節=8比特。比特是計算機中最小的數據單位,是…

    編程 2025-04-25
  • 深入理解Flutter StreamBuilder

    一、什麼是Flutter StreamBuilder? Flutter StreamBuilder是Flutter框架中的一個內置小部件,它可以監測數據流(Stream)中數據的變…

    編程 2025-04-25
  • 深入探討OpenCV版本

    OpenCV是一個用於計算機視覺應用程序的開源庫。它是由英特爾公司創建的,現已由Willow Garage管理。OpenCV旨在提供一個易於使用的計算機視覺和機器學習基礎架構,以實…

    編程 2025-04-25
  • 深入了解scala-maven-plugin

    一、簡介 Scala-maven-plugin 是一個創造和管理 Scala 項目的maven插件,它可以自動生成基本項目結構、依賴配置、Scala文件等。使用它可以使我們專註於代…

    編程 2025-04-25
  • 浮點型數據的細節揭秘

    一、基本概念 浮點型數據是指可以表示實數的一種數據類型。在C語言中,浮點型數據有兩種類型:float(單精度浮點數)和double(雙精度浮點數)。其中,float數據類型佔用4個…

    編程 2025-04-25
  • 深入了解LaTeX的腳註(latexfootnote)

    一、基本介紹 LaTeX作為一種排版軟件,具有各種各樣的功能,其中腳註(footnote)是一個十分重要的功能之一。在LaTeX中,腳註是用命令latexfootnote來實現的。…

    編程 2025-04-25
  • 深入了解Python包

    一、包的概念 Python中一個程序就是一個模塊,而一個模塊可以引入另一個模塊,這樣就形成了包。包就是有多個模塊組成的一個大模塊,也可以看做是一個文件夾。包可以有效地組織代碼和數據…

    編程 2025-04-25

發表回復

登錄後才能評論