使用STL库sort函数对vector进行排序
使用STL库sort函数对vector进行排序,vector的内容为对象的指针,而不是对象。
代码如下
1 #include <stdio.h> 2 #include <vector> 3 #include <algorithm> 4 5 using namespace std; 6 7 class Elm 8 { 9 public: 10 int m_iSortProof; 11 12 private: 13 int __m_iValue; 14 static int __m_iCnt; 15 16 public: 17 Elm(); 18 int getValue(int iX); 19 void printElm(); 20 }; 21 22 int Elm::__m_iCnt = 0; 23 24 Elm::Elm() 25 { 26 __m_iCnt ++; 27 __m_iValue = __m_iCnt; 28 m_iSortProof = getValue(__m_iCnt); 29 } 30 31 /* (x-10.3)^2 + 0.6*/ 32 int Elm::getValue(int iX) 33 { 34 float fX = (float)iX - 10.3; 35 36 float fY = fX * fX + 0.6; 37 38 return (int)fY; 39 } 40 41 void Elm::printElm() 42 { 43 printf("value : %3d, proof : %3d\n", __m_iValue, m_iSortProof); 44 } 45 46 /*z -> a*/ 47 bool compare(const Elm * a, const Elm * b) 48 { 49 return a->m_iSortProof > b->m_iSortProof; 50 } 51 52 int main(int argc, char * argv[]) 53 { 54 vector<Elm *> vecpList; 55 int i = 0; 56 for(i = 0; i < 20; i++) 57 { 58 Elm * pElm = new Elm; 59 vecpList.push_back(pElm); 60 } 61 for(vector<Elm *>::iterator pE = vecpList.begin(); pE != vecpList.end(); pE++) 62 { 63 (*pE)->printElm(); 64 } 65 /*使用sort对vector进行排序*/ 66 sort(vecpList.begin(), vecpList.end(), compare); 67 printf("\033[0;34m----------------sorted----------------\033[0m\n"); 68 for(vector<Elm *>::iterator pE = vecpList.begin(); pE != vecpList.end(); pE++) 69 { 70 (*pE)->printElm(); 71 } 72 73 return 0; 74 }
运行结果如下
1、排序前
value : 1, proof : 87 value : 2, proof : 69 value : 3, proof : 53 value : 4, proof : 40 value : 5, proof : 28 value : 6, proof : 19 value : 7, proof : 11 value : 8, proof : 5 value : 9, proof : 2 value : 10, proof : 0 value : 11, proof : 1 value : 12, proof : 3 value : 13, proof : 7 value : 14, proof : 14 value : 15, proof : 22 value : 16, proof : 33 value : 17, proof : 45 value : 18, proof : 59 value : 19, proof : 76 value : 20, proof : 94
排序后
value : 20, proof : 94 value : 1, proof : 87 value : 19, proof : 76 value : 2, proof : 69 value : 18, proof : 59 value : 3, proof : 53 value : 17, proof : 45 value : 4, proof : 40 value : 16, proof : 33 value : 5, proof : 28 value : 15, proof : 22 value : 6, proof : 19 value : 14, proof : 14 value : 7, proof : 11 value : 13, proof : 7 value : 8, proof : 5 value : 12, proof : 3 value : 9, proof : 2 value : 11, proof : 1 value : 10, proof : 0
作 者:fengbohello
个人网站:http://www.fengbohello.top/
E-mail : fengbohello@foxmail.com
欢迎转载,转载请注明作者和出处。
因作者水平有限,不免出现遗漏和错误。希望热心的同学能够帮我指出来,我会尽快修改。愿大家共同进步,阿里嘎多~
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?