[STL] list merge 函数

[STL] list merge 函数CopyFrom: http://blog.csdn.net/ysuliu/article/details/3497862STLlist容器由于采用了双向迭代器,不支持随机访问,所以标准库的merge(),sort()等功能函数都不适用,list单独实现了merge(),sort()等函数。首先说一下merge()(以voidmerge(list&__x);为例)按照

大家好,又见面了,我是你们的朋友全栈君。

Copy From: http://blog.csdn.net/ysuliu/article/details/3497862

STL list容器由于采用了双向迭代器,不支持随机访问,所以标准库的merge(), sort()等功能函数都不适用,list单独实现了merge(),sort()等函数。首先说一下merge() (以void merge(list& __x); 为例)

按照函数声明的注释:

/**
       *  @brief  Merge sorted lists.
       *  @param  x  Sorted list to merge.
       *
       *  Assumes that both @a x and this list are sorted according to
       *  operator<().  Merges elements of @a x into this list in
       *  sorted order, leaving @a x empty when complete.  Elements in
       *  this list precede elements in @a x that are equal.
       */

 

它应该合并两个有序的list, 故做此验证:

  1. #include <iostream>
  2. #include <list>
  3. #include <iomanip>
  4. using namespace std;
  5. int main()
  6. {
  7.     // 有序数据 
  8.     int A1[]={1,2,3,4,5,6};
  9.     int A2[]={2,4,6,8,9,10};
  10.     
  11.     // 无序数据
  12.     int A3[]={1,2,3,4,6,9};
  13.     int A4[]={5,6,7,8,9,2};
  14.     
  15.     //有序链表 
  16.     list<int> iL1(A1, A1+6);
  17.     list<int> iL2(A2, A2+6);
  18.     
  19.     //无序链表
  20.     list<int> iL3(A3, A3+6);
  21.     list<int> iL4(A4, A4+6);
  22.     
  23.     iL1.merge(iL2);
  24.     iL3.merge(iL4);
  25.     
  26.     list<int>::iterator it = iL1.begin();
  27.     
  28.     while(it!=iL1.end())
  29.     {
  30.         cout<<setw(3)<<*it++;
  31.     }
  32.     cout<<endl;
  33.     it=iL3.begin();
  34.     while(it!=iL3.end())
  35.     {
  36.         cout<<setw(3)<<*it++;
  37.     }    
  38.     cout<<endl;
  39.     
  40.     system(“pause”);
  41.     return 0;
  42. }

输出为:

  1.   1  2  2  3  4  4  5  6  6  8  9 10
  2.   1  2  3  4  5  6  6  7  8  9  9  2

可以看到合并的第一个list仍是有序的,第二个最后一个元素是2,无序。

 

得到结论:

 

当源list均有序时,得到的list仍是有序的

当源list无序时,得到的list不能保证有序,之所以这样说是因为,当list1的前两个元素即表现出无序时,合并后的结果将是直接把list2接到list1的后面。。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/142736.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月23日 上午7:00
下一篇 2022年5月23日 上午7:00


相关推荐

  • Latex公式换行与对齐

    Latex公式换行与对齐Latex公式换行与对齐1、应用amsmath包:\usepackage{amsmath}2、公式中用aligned:\begin{equation}\begin{aligned}……\end{aligned}\end{equation}或者直接用align:\begin{align}……\end{align}3、换行时用“\”换行符\begin{align}a=1+2+3+4+5\\=6+9\end{align}效果:4、左对齐用“&amp

    2022年6月12日
    62
  • jmap的使用以及内存溢出分析

    jmap的使用以及内存溢出分析jmap 的使用以及内存溢出分析 jmap java 内存映像工具 jmap MemoryMapfor 命令用于生成堆转储快照 一般称为 heapdump 或 dump 文件 还有几种方式获取 dump 文件 使用 JVM 参数选项 XX HeapDumpOnOu 参数 可以让虚拟机在 OOM 异常出现之后自动生成 dump 文件 通过 XX HeapDumpPath path 设置 dump 文件路径 有时候 dump 文件比较大的时候可能无法自动导出 这时候就需要使用 jmap dump 手动导

    2025年12月6日
    5
  • 华为C++面试题(产品经理逻辑面试题)

    1.static有什么用途?(请至少说明两种)   1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。   2)在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。它是一个本地的全局变量。   3)在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。那就是,这个函数被限制在声明它的模块的本地范

    2022年4月11日
    57
  • 2012年第一篇博文——致谢:2011年中国IT十大杰出博客获奖感言「建议收藏」

    2012年第一篇博文——致谢:2011年中国IT十大杰出博客获奖感言「建议收藏」在2012新年伊始之际,非常荣幸获得了2011年度十大杰出IT博客的殊荣,非常感谢各界朋友和同仁、51CTO的编辑、《网络协议本质论》和《蜕变:从菜鸟到Linux安全专家》等个人专著的热心读者在大赛期间对我的支持、关心和陪伴。51CTO博客是一个非常好的展示自己、促进交流、提升自我的平台。我以前专注于技术研究和项目管理,2年前通过51CTO这么一个好的平台找到了一条与大…

    2022年7月21日
    14
  • 字符串正则匹配leetcode_正则在线检验

    字符串正则匹配leetcode_正则在线检验原题链接给你一个字符串 s 和一个字符规律 p,请你来实现一个支持 ‘.’ 和 ‘*’ 的正则表达式匹配。‘.’ 匹配任意单个字符‘*’ 匹配零个或多个前面的那一个元素所谓匹配,是要涵盖 整个 字符串 s的,而不是部分字符串。示例 1:输入:s = “aa” p = “a”输出:false解释:”a” 无法匹配 “aa” 整个字符串。示例 2:输入:s = “aa” p = “a*”输出:true解释:因为 ‘*’ 代表可以匹配零个或多个前面的那一个元素, 在这里前面的元素就是

    2022年8月8日
    9
  • 基于php教师档案管理系统毕业设计

    基于php教师档案管理系统毕业设计获取项目源文件,联系Q:1415736481,可指导毕设,课设随着经济的发展和社会的进步,高校的现代化管理逐渐被人们所重视,利用计算机对高校的管理在各个领域中都有广阔的发展空间和前景。高校教师档案管理系统的设计与实现对高等院校的决策者和管理者来说至关重要,对教育系统来说更是不可缺少的。本系统采用PHP语言和MySQL数据库等技术,基于B/S模式,根据管理员、教务处管理员、教师三种不同的用户权限…

    2025年6月27日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号