[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的后面。。

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • CSS calc()函数与单位vh 常见height:100vh[通俗易懂]

    CSS calc()函数与单位vh 常见height:100vh[通俗易懂]calc()函数属于CSS3版本内容,用于动态计算长度值。例如:width:calc(100%-10px);需要注意的是,运算符前后都需要保留一个空格。calc()函数支持”+”,”-“,”*”,”/”运算;举例,给一个div动态设置宽度如下:#divBox{position:absolute;left:50px;width:calc(100%-100p…

  • Java不可重入锁和可重入锁理解[通俗易懂]

    Java不可重入锁和可重入锁理解[通俗易懂]最近正在阅读JavaReentrantLock源码,始终对可重入和不可重入概念理解不透彻,进行学习后记录在这里。基础知识Java多线程的wait()方法和notify()方法这两个方法是成对出现和使用的,要执行这两个方法,有一个前提就是,当前线程必须获其对象的monitor(俗称“锁”),否则会抛出IllegalMonitorStateException异常,所以这两个方法必须在同步…

  • 指针指向常量_常量指针的四种

    指针指向常量_常量指针的四种const关键字指针常量和常量指针都离不开const关键字,我们先来了解一下什么是const关键字,const被用来定义常量,如果将一个变量加上const关键字,则被修饰的变量的值将无法改变。这个变量的值只能被访问,无法被修改。const关键字可以修饰变量或者指针。下面是const修饰变量的用法:constinta=6;或者intconsta=6;此时变量a…

    2022年10月20日
  • MySQL中count(字段) ,count(主键 id) ,count(1)和count(*)的区别

    MySQL中count(字段) ,count(主键 id) ,count(1)和count(*)的区别

  • 什么是SSH 以及常见的ssh 功能

    什么是SSH 以及常见的ssh 功能什么是SSH?简单说,SSH是一种网络协议,用于计算机之间的加密登录。如果一个用户从本地计算机,使用SSH协议登录另一台远程计算机,我们就可以认为,这种登录是安全的,即使被中途截获,密码也不会泄露。最早的时候,互联网通信都是明文通信,一旦被截获,内容就暴露无疑。1995年,芬兰学者TatuYlonen设计了SSH协议,将登录信息全部加密,成为互联网安全的一个基本解决方案,迅速在全世界获得推广,目…

  • Atom动态代码插件Activate Power Mode常用设置[通俗易懂]

    Atom动态代码插件Activate Power Mode常用设置[通俗易懂]相信用过Atom的人都知道它很方便,那么小编在这就介绍下ActivatePowerMode插件的一些实用设置如下:效果的起步阈值:刚装上插件后,效果是你按了20个代码后才有动态效果,在这里可以修改为立马有动态效果目录:Setting/ComboMode中找ComboMode-ActivationThreshold动态效果的声音调节:小编吐槽以下,我网上百度了下怎么调节声音大小,结果就没

发表回复

您的电子邮箱地址不会被公开。

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