zoukankan      html  css  js  c++  java
  • python 按二维数组的某行或列排序 (numpy lexsort)

    https://www.cnblogs.com/liyuxia713/p/7082091.html

    lexsort支持对数组按指定行或列的顺序排序;是间接排序,lexsort不修改原数组,返回索引。

    (对应lexsort 一维数组的是argsort a.argsort()这么使用就可以;argsort也不修改原数组, 返回索引)
     
    默认按最后一行元素有小到大排序, 返回最后一行元素排序后索引所在位置。
    设数组a, 返回的索引ind,ind返回的是一维数组
    对于一维数组, a[ind]就是排序后的数组。
    对于二维数组下面会详细举例。
     
    import numpy as np
     
    >>> a
    array([[ 2,  7,  4,  2],
           [35,  9,  1,  5],
           [22, 12,  3,  2]])
     
    按最后一列顺序排序
    >>> a[np.lexsort(a.T)]
    array([[22, 12,  3,  2],
           [ 2,  7,  4,  2],
           [35,  9,  1,  5]])
     
    按最后一列逆序排序
    >>>a[np.lexsort(-a.T)]
    array([[35,  9,  1,  5],
           [ 2,  7,  4,  2],
           [22, 12,  3,  2]])
     
    按第一列顺序排序
    >>> a[np.lexsort(a[:,::-1].T)]
    array([[ 2,  7,  4,  2],
           [22, 12,  3,  2],
           [35,  9,  1,  5]])
     
    按最后一行顺序排序
    >>> a.T[np.lexsort(a)].T
    array([[ 2,  4,  7,  2],
           [ 5,  1,  9, 35],
           [ 2,  3, 12, 22]])
     
    按第一行顺序排序
    >>> a.T[np.lexsort(a[::-1,:])].T
    array([[ 2,  2,  4,  7],
           [ 5, 35,  1,  9],
           [ 2, 22,  3, 12]])
  • 相关阅读:
    随笔导航
    利用CORDIC算法计算三角函数
    粒子群算法求一元函数最值问题
    基于粒子群算法的分组背包MATLAB实现
    遇到过的MATLAB函数小总结
    FFT原理及C++与MATLAB混合编程详细介绍
    DPSK通信系统的FPGA实现
    矩阵QR分解的MATLAB与C++实现
    矩阵LU分解的MATLAB与C++实现
    两种频率调制(FM)方法的MATLAB实现
  • 原文地址:https://www.cnblogs.com/focus-z/p/13799524.html
Copyright © 2011-2022 走看看