结构体排序

经常碰到结构体排序的问题,在此总结一下。
以一个简单的例题开始:

例1、有三个人(Person结构体),每个人都有name(string型)和age(int型)两个属性,现在需要按照下面的规则排序:先以姓名按从小到大排序(如abc<abd),如果姓名相同,则按照年龄从大到小排序。

#include<iostream>
#include<string>
using namespace std;
struct Person{
    string name;
    int age;
};
void exchange(Person &a,Person &b){
    //注意交换的时候,中间变量是结构体类型,而不是基本数据类型(int,char,string)等。
    Person temp;
    temp=a;
    a=b;
    b=temp;
}
int main(){
    Person p[3];
    int i,j;
    for(i=0;i<3;i++){
        cin>>p[i].name>>p[i].age;
    }
    //冒泡排序实现
    for(i=0;i<3;i++){
        for(j=0;j<3-i-1;j++){
            if(p[j].name<p[j+1].name){
                exchange(p[j],p[j+1]);
            } else if(p[j].name==p[j+1].name){
                if(p[j].age<p[j+1].age){
                    exchange(p[j],p[j+1]);
                }
            }
        }
    }
    //依次输出
    for(i=0;i<3;i++){
        cout<<p[i].name<<‘ ‘<<p[i].age<<endl;
    }
}

这个代码是我最初写的,毫无技术含量,参加过ACM或者程序竞赛的朋友一看就知道这样做太复杂,因为有一个简单的sort函数,只要一行代码即可实现。

sort函数首先是一个排序函数,不仅可以用来给数字排序,还可以给字符串排序,默认的是升序,如果需要降序的话,可以自己写一个函数cmp函数(函数名可自拟,通常用cmp),然后在sort函数中,加上(cmp)函数名即可。

例2、随机产生10个数,并且从大到小输出

#include<iostream>
#include<algorithm>
#include<cstdlib>
bool cmp(int a,int b){
    return a>b;
}
using namespace std;
int main(){
    int A[10],i;
    for(i=0;i<10;i++){
        A[i]=rand();
    }
    sort(A,A+10,cmp);
    for(i=0;i<10;i++){
        cout<<A[i]<<‘ ‘;
    }
}

注意:使用sort函数,必须要加#include<algorithm>头文件。在sort函数中,第一个参数为数组(字符串)名,第二个参数为排序范围,是从A到A+n(n为长度),第三个参数可省,省略后则代表默认升序,加上自己写的cmp函数,即可按照cmp中的规定进行排序。

既然sort函数这么神奇,那他肯定也是可以对结构体或者对象进行排序的。

时间: 2024-10-26 17:55:35

结构体排序的相关文章

【转】 从最简单的vector中sort用法到自定义比较函数comp后对结构体排序的sort算法

sort函数在使用中非常好用,也非常简单,而且效率与冒泡或者选择排序不是一个数量级.本文就sort函数在vector中的用法分为sort函数入门用法与自定义comp比较函数比较结构体这两个最基本的功能讲讲其用法: 1.sort入门: 使用sort需要包含algorithm头文件,完整代码如下 #include<iostream> #include<vector> #include<algorithm>//貌似可以不用,但最好加上. using namespace std

HDU 1084 [What Is Your Grade?] 结构体排序

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1084 题目大意:共5道题,N个学生.做出5道满分,0道50分.做出1-4道的同学,若在前50%(向下取整),则获得95.85.75.65,若在后50%则获得90.80.70.60. 关键思想:结构体排序 //结构体排序,考虑边界 #include <iostream> #include <algorithm> #include <cmath> #include <me

C++结构体排序

在C++中,对结构体的排序方式比C语言丰富的多.在C语言中,我们主要是通过qsort进行排序操作(抛开手写排序算法不说). 在C++<algorithm>中,有一个十分强大的排序函数sort,他的内部综合了许多种排序算法,因此非常高效.并且,用它来对结构体排序也十分方便. 先贴一段示例代码: 1 #include <cstdio> 2 #include <queue> 3 #include <vector> 4 #include <algorithm&

HDOJ 1009. Fat Mouse&#39; Trade 贪心 结构体排序

FatMouse' Trade Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 56784    Accepted Submission(s): 19009 Problem Description FatMouse prepared M pounds of cat food, ready to trade with the cats g

最小生成树模板+并查集(隐藏)+结构体排序模板

minn[101],g[101][101],u[101]; memset(u,1,sizeof(u)); memset(minn,0x7f,sizeof(minn)); minn[1]=0; u[1]=0; i,j,k,m; total=0; for(i=1;i<=n;i++) { k=0; for(j=1;j<=n;j++) if(u[j]&&(minn[k]>minn[j])) k=j; u[k]=0; for(j=1;j<=n;j++) if(u[j]&

HDU 1862 EXCEL排序(结构体排序)

EXCEL排序 Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 16387    Accepted Submission(s): 6137 Problem Description Excel可以对一组纪录按任意指定列排序.现请你编写程序实现类似功能. Input 测试输入包含若干测试用例.每个测试用例的第1行包含两个整数 N (<=1

HDU 2409 Team Arrangement (结构体排序)

题目链接:HDU 2409 Team Arrangement 题意:给出22个人(编号,名字,踢的位置,在队里的时间),让我们选DD-MM-SS的阵型+一个守门员.在选出队长(时间在最久的就是队长,时间相同编号大为队长),选人的顺序是从编号小的开始. 结构体排序就好了,注意出输出是按队长,D,M,S的顺序,选队长记录队长的编号(而不是下标,我的代码之后还要排序). AC代码: #include<stdio.h> #include<string.h> #include<algo

CodeForces 151 B 结构体排序。

E - 结构体又来了呦 Time Limit:2000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u Submit Status Practice CodeForces 151B Description Winters are just damn freezing cold in Nvodsk! That's why a group of n friends prefers to take a taxi, order

转载 从最简单的vector中sort用法到自定义比较函数comp后对结构体排序的sort算法

转载自:http://www.cnblogs.com/cj695/p/3863142.html sort函数在使用中非常好用,也非常简单,而且效率与冒泡或者选择排序不是一个数量级.本文就sort函数在vector中的用法分为sort函数入门用法与自定义comp比较函数比较结构体这两个最基本的功能讲讲其用法: 1.sort入门: 使用sort需要包含algorithm头文件,完整代码如下 #include<iostream> #include<vector> #include<