C++使用sort通过cmp实现对结构体的排序
#include <stdio.h> #include<iostream> #include <string.h> #include<stdlib.h> using namespace std; //C语言的qsort与c++语言的sort //由于qsort需要使用指针,而且写法上也没有C++的sort简单, //所以以后使用C++的sort来解决排序问题 struct Student{ char name[10]; char id[10]; int score; int r;//排名rank }; //由于使用sort排名需要提供bool cmp()函数,所以下面定义cmp函数 bool cmp(Student a,Student b){ if(a.score!=b.score) return a.score>b.score;//从大到小a>b,从小到大a<b else return strcmp(a.name,b.name)<0;//strcmp是string.h头文件下用来比较两个char型字符串的字典序大小, //str1小于str2返回负数 } int main(){ //sort(首位元素地址,末尾元素地址加一,cmp) return 0; }
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。
- 上一篇: 关于拖延症的一些观点
- 下一篇: C++ 排序函数 sort(),qsort()的用法