C++ list.merge()使用方法

(1)先创建两个list

list<CAnsParagraph> * SingleAnsPartParaList = new list<CAnsParagraph>;

list<CAnsParagraph> * SingleAnsPartParaList = new list<CAnsParagraph>;

(2)赋值操作

 省略。。。。。。

(3)合并两个list

(*LeadPartParaList).merge(*SingleAnsPartParaList)     完美报错--------由于合并的时候会进行排序,需要重载“<”运算符

两种重载方法:

         1.在自定义类型中重载“<”:      

                    bool  operator<(CAnsParagraph &ansPara) 
                           {
                                return false;
                           }

            使用(*LeadPartParaList).merge(*SingleAnsPartParaList)即可。

      2.自定义类型

                  struct MyStructOP
                     {
                          bool operator()(CAnsParagraph &ansPara1, CAnsParagraph &ansPara2)
                            {
                                return false;
                            }
                     };

        函数调用:(*LeadPartParaList).merge(*SingleAnsPartParaList, MyStructOP());  即重载“()”运算符,将排序设置为 false,即按照插入顺序,进行比较即可。

 

 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++中,list是一个双向链表的容器,它允许快速的插入和删除操作,但是访问元素的速度较慢。要使用list,需要包含头文件<list>。可以通过下面的代码来定义和使用list: #include <iostream> #include <list> using namespace std; int main() { list<int> l1; // 定义一个空的list list<int> l2(2, 0); // 定义一个有两个元素值为0的list l1.push_back(1); // 在list末尾插入一个元素 l1.push_back(2); l2.push_back(3); l1.merge(l2, greater<int>()); // 合并l1和l2,并按照降序排序 list<int>::iterator iter; for(iter = l1.begin(); iter != l1.end(); iter++) { cout << *iter << " "; // 遍历输出list中的元素 } cout << endl << endl; if(l2.empty()) { cout << "l2 变为空 !!"; // 判断list是否为空 } cout << endl << endl; return 0; } 这段代码演示了list的一些常用操作。其中,push_back()函数用于在list末尾插入元素,merge()函数用于合并两个list并按照给定的排序方式进行排序。在遍历list时,可以使用迭代器iterator,通过循环将元素输出。另外,empty()函数可以判断list是否为空。 总之,list是一个很有用的容器,可以用于快速的插入和删除操作,适合于一些需要经常修改数据的场景。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [C++list用法详解](https://blog.csdn.net/fengruoying93/article/details/108222992)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [C++list使用方法及常用list操作总结](https://download.csdn.net/download/weixin_38528888/13786182)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值