16.7.4【列表list容器的数据存取、反转和排序】
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 | #include<iostream> #include<cstdlib> using namespace std; #include <list> #include<algorithm> /* 3.7.6 list容器数据存取 front(); //返回第一个元素。 back(); //返回最后一个元素。 3.7.7 list容器反转和排序 reverse(); //反转链表 sort(); //链表排序 */ void print_list( const list< int > & L) { for (list< int >::const_iterator cit=L.begin(); cit!=L.end(); cit++) { cout << *cit << " " ; } cout << endl; } void test376() { list< int > l1; l1.push_back(10); l1.push_back(20); l1.push_back(30); l1.push_back(40); //l1[0]; //l1.at(0); //不可以用[]或at()直接访问list容器中的元素。原因是list本质是链表,而不是用连续线性空间存储数据,迭代器不支持随机访问。 cout << "first:" << l1.front() << endl; cout << "last:" << l1.back() << endl; /* list<int>::iterator it = l1.begin(); //支持双向 it++; //前向OK, it--; //后向OK //但不支持随机访问 //it = it + 1; //error //it += 3; //error */ } void test377_1() { list< int > l1; l1.push_back(20); l1.push_back(50); l1.push_back(10); l1.push_back(30); l1.push_back(40); cout << "翻转前:" << endl; print_list(l1); l1.reverse(); cout << "翻转后:" << endl; print_list(l1); } bool my_compare( int num1, int num2) { //降序:令 前一个数 > 后一个数 return num1 > num2; } void test377_2() { list< int > l1; l1.push_back(20); l1.push_back(50); l1.push_back(10); l1.push_back(30); l1.push_back(40); list< int > l2; l2 = l1; cout << "排序前:" << endl; print_list(l1); //sort(l1.begin(), l1.end()); //error //所有不支持随机访问迭代器的容器,不可以使用标准算法库的算法 //但,这些不支持随机访问迭代器的容器,自己内部会提供一些对应功能的算法 l1.sort(); //ok 默认升序 cout << "排序后:" << endl; print_list(l1); cout << "排序前:" << endl; print_list(l2); l2.sort(my_compare); //利用回调函数或仿函数实现降序(此处为回调函数) cout << "排序后:" << endl; print_list(l2); } int main() { test376(); test377_1(); test377_2(); system ( "pause" ); return 0; } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!