sort(); 位于C++

头文件 #include<algorithm>中

数组排序(从小到大,从大到小)

结构体排序(数字参数从大到小...字符串为参数 字典序....)

代码示例:(直接复制运行对比结果看源码)

#include<iostream>

#include<algorithm>

using namespace std;
// 对下文所有函数进行声明

struct node
{
  int sum;
  char s[10];
} str[10];


int cmpn1(node a,node b)
{
  return a.sum>b.sum;
}


int cmpn2(node a,node b)
{
  return a.s>b.s;
}


int cmp(int a,int b)
{
  return a>b;
}

int main()
{
  int a[100]= {1,3,6,9,4,2,3,6,7,10};
  //一共10个
  cout<<"a数组最初状态\n"<<endl;
  for(int i=0; i<10; i++)
    cout<<a[i]<<endl;
  //需要排序首位置加上需排序的位长
  cout<<"默认是从大到小排序\n"<<endl;
  sort(a,a+10);
  for(int i=0; i<10; i++)
    cout<<a[i]<<endl;
  cout<<endl;
  cout<<"引入cmp()从大到小\n"<<endl;
  sort(a,a+10,cmp);
  for(int i=0; i<10; i++)
    cout<<a[i]<<endl;
  cout<<endl;
  // 结构体赋值
  for(int i=0; i<10; i++)
  {
    str[i].sum=i;
    str[i].s[0]='a'+i;
  }
  cout<<"以sum为参数 调用cmp1进行从大到小\n"<<endl;
  sort(str,str+10,cmpn1);
  for(int i=0; i<10; i++)
    cout<<str[i].sum<<endl;
  cout<<endl;
  cout<<"经过sum作为参数排序后,字符串目前状态\n"<<endl;
  for(int i=0; i<10; i++)
    cout<<str[i].s<<endl;
  cout<<endl;
  cout<<"以s为参数 调用cmp2进行字典序\n"<<endl;
  sort(str,str+10,cmpn2);
  for(int i=0; i<10; i++)
    cout<<str[i].s<<endl;
  cout<<endl;

  return 0;

}

sort();对结构体数组的排序的更多相关文章

  1. 关于priority_queue和sort()对结构体数组的排序

    知乎的这个答案很清晰https://www.zhihu.com/question/35736022 #include <iostream> #include <algorithm&g ...

  2. HDU - 1789 Doing Homework again(贪心) ~~~学了一波sort对结构体排序

    题目中因为天数和分数是对应的,所以我们使用一个结构体来存分数和截止如期. 一开始做这道题的时候,很自然的就想到对天数排序,然后天数一样的分数从大到小排序,最后WA了之后才发现没有做到"舍小取 ...

  3. sort+结构体实现二级排序

    之前介绍的sort函数由于其效率较高,使用较为简单让我用起来那叫一个爽,今天再写一篇使用sort+结构体实现二级排序的方法. 还是先想个问题吧,比如我想输入5个同学的名字和身高,然后得到他们身高的降序 ...

  4. qsort 与sort 对结构体排序实例

    qsort 与sort 对结构体排序实例 #include<bits/stdc++.h> using namespace std; typedef struct { string book ...

  5. golang结构体数组

    转自: https://www.liaotaoo.cn/200.html package main import "fmt" type student struct{ id int ...

  6. C#调用C++DLL传递结构体数组的终极解决方案

    在项目开发时,要调用C++封装的DLL,普通的类型C#上一般都对应,只要用DllImport传入从DLL中引入函数就可以了.但是当传递的是结构体.结构体数组或者结构体指针的时候,就会发现C#上没有类型 ...

  7. 绝对好文C#调用C++DLL传递结构体数组的终极解决方案

    C#调用C++DLL传递结构体数组的终极解决方案 时间 2013-09-17 18:40:56 CSDN博客相似文章 (0) 原文  http://blog.csdn.net/xxdddail/art ...

  8. HDU 2555 陷阱(模拟,结构体数组)

    这道题目意思很明白,有不确定的数据沙包和陷阱,还要排序···那就必须要用结构体+数组 /* 在地面上有N 个大小不等的长方形陷阱,每个陷阱的周长各不相同,每个参赛者都有一个沙包,闭上眼睛把它扔向地面, ...

  9. Problem T: 结构体--学生信息排序

    Problem T: 结构体--学生信息排序 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 2219  Solved: 1305[Submit][Sta ...

随机推荐

  1. SOUI taobao SVN目录结构说明

  2. 1、python基础

    本节主要内容 语言特性 变量 注释 字符串拼接 循环 数据类型与字符编码 三元运算 进制 一 .语言特性 python是一门动态解释性的强类型定义语言. 1.编译和解释语言: 简单讲,编译(compl ...

  3. PSO:利用PSO+ω参数实现对一元函数y = sin(10*pi*x) ./ x进行求解优化,找到最优个体适应度—Jason niu

    x = 1:0.01:2; y = sin(10*pi*x) ./ x; figure plot(x, y) title('绘制目标函数曲线图—Jason niu'); hold on c1 = 1. ...

  4. Object 中 equals()使用

    详细看: https://www.cnblogs.com/naihuangbao/p/9445027.html 1. ==是判断两个变量或实例是不是指向同一个内存空间equals是判断两个变量或实例所 ...

  5. 对迭代器操作的python 模块

    import itertools import more_itertools 目前用到的more_itertools.ilen(range(10)) --->返回可迭代的数量.这回消耗迭代,小心 ...

  6. 面试题: 多个 await 处理,有一个失败,就算作失败

    面试题: 多个 await 处理,有一个失败,就算作失败 ? Promise.all([p1, p2, p3....])    // 返回的也是一个 Promise 对象 -------- asait ...

  7. mysql 查询 两个表中不同字段的 和,并通过两个表的时间来分组

    ( SELECT sum( a.cost_sum ) AS sum_cost, sum( a.phone_sum ) AS sum_phone, sum( a.arrive_sum ) AS sum_ ...

  8. Nestjs Graphql

    文档 工作示例 安装依赖: npm i --save @nestjs/graphql apollo-server-express graphql-tools graphql app.module.ts ...

  9. 问题:怎么把mysql的系统时间调整为电脑的时间?(已解决)

    我的mysql是5.7版本. 浏览mysql的错误日志的时候,发现时间和电脑时间不一致. 查了一下,知道这个时间和log_timestamps有关, 就在mysql里执行下面一句话: SET GLOB ...

  10. OO第二次阶段性总结

    前两次作业我都无效了……用了很久时间但还是没能弄明白多线程的写法,以后还是要学会即时的多问问会的同学吧…… 以及我的Mertrics在挣扎很久之后还是用不了……跪了 第七次作业 第七次作业能够完成的原 ...