Sort()函数用法:比较函数写法

sort 函数

sort函数可以三个参数也可以两个参数,必须包含头文件

#include < algorithm>
using namespace std; 

它使用的排序方法是类似于快排的方法,时间复杂度为o(nlog(n))

Sort函数有三个参数:(第三个参数可不写)
(1)第一个是要排序的数组的起始地址。
(2)第二个是结束的地址(最后一位要排序的地址)
(3)第三个参数是排序的方法,可以是「降序」也可是「升序」,
第三个参数可省略,此时默认的排序方法是「升序」排序。

两个参数用法

#include <iostream>
#include <algorithm>
using namespace std;
int main()
{
 int a[20]={2,4,1,23,5,76,0,43,24,65},i;
 for(i=0;i<20;i++)  cout<<a[i]<<endl;
 sort(a,a+20);
 for(i=0;i<20;i++) cout<<a[i]<<endl;
 return 0;
}

输出结果是升序排列。(两个参数的sort默认升序排序)

三个参数用法

sort(arr.begin(),arr.end(),compare);
可以通过编写compare函数改变Sort的排序规则。

降序

bool compare(int a,int b){
  return a>b; //降序排列,如果改为return a<b,则为升序
}
 int a[20]={2,4,1,23,5,76,0,43,24,65},i;
 sort(a,a+20,compare);

}
绝对值排序

#include <cmath>
 bool compare(int a, int b){
    return abs(a) > abs(b);
}

结构体排序

struct node{
    int u, v, w;
};
bool cmp(node a, node b){
    if(a.w < b.w ) //按照w的值进行的是:升序排列 !
        return true;
    else return false;
}

//还可以这样写

bool cmp(node a, node b)
{
    return a.w<b.w; //升序
}

当然cmp函数也可以写的稍微复杂点,也就是说,按照优先级对结构体的多个成员按照某种规则排序
//先按照w的值升序排序,如果w相等,再按照v的值升序排序

bool cmp(node a, node b)
{
   if(a.w==b.w)
       return a.v<b.v;
   else
       return a.w<b.w;
}

//或者这样写

bool cmp(node a, node b){
    if(a.w<b.w)
        return true;
    if(a.w==b.w && a.v<b.v )
        return true;
    return false;
}
  • 55
    点赞
  • 195
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
在MATLAB中,sort函数用于对数组进行排序。sort函数用法如下: 1. [Y,I] = sort(X,DIM,MODE):按指定维度DIM对数组X进行排序,并返回排序后的数组Y和排序后的索引数组I。MODE参数可选,默认为'ascend'表示升序排列,也可以指定为'descend'表示降序排列。 2. sort(X):对矩阵X的各列进行升序排列。 3. sort(X,dim):按指定维度dim对矩阵X进行排序,当dim=1时等效于sort(X)。 sort函数的实现过程可以通过循环语句来实现,例如按行排序可以使用循环语句和索引数组来实现: ```matlab [B,indb] = sort(A,2); % 按行排序的sort函数实现 for i = 1:size(A,1) B1(i,:) = A(i,indb(i,:)); end ``` 按列排序也可以使用循环语句和索引数组来实现: ```matlab [C,indc] = sort(A,1); % 按列排序的sort函数实现 for j = 1:size(A,2) C1(:,j) = A(indc(:,j),j); end ``` sort函数还可以根据指定的方向进行排列,可以使用参数mode来指定排序方向,可选的值有'ascend'表示升序排列(默认值)和'descend'表示降序排列。 sort函数还可以返回索引数组,其大小与原数组相同。如果原数组中有重复出现的相等值,则返回原来相对位置的索引。 在排列复数项时,sort函数遵循以下规则:如果数组A中有复数项r和s,满足以下任何一个条件,r将在sort(A)中排在s前面:abs(r) < abs(s)或abs(r) = abs(s)并且angle(r) < angle(s),其中-pi < angle(r) <= pi。 以下是sort函数的一些应用举例: 例1:对矩阵A进行每一维的排序,然后再对其进行第三次排序,并返回排序结果的索引矩阵: ```matlab A = [3 7 5; 0 4 2]; sort(A,1) % 按列排序 sort(A,2) % 按行排序 [B,IX] = sort(A,2) % 返回排序后的数组和索引数组 ``` 例2:按降序排列每一列的元素: ```matlab A = [375 683 042]; sort(A,1,'descend') % 按列降序排列 sort(A,'descend') % 等价于上一行的写法 ``` 以上是MATLAB中sort函数用法和实现过程的介绍。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值