C++ list容器的splice方法

C++ list容器的splice方法list容器底层实现是一个带头结点的双向链表,由于链表的每个节点是单独开辟的,所以链表在移动数据,或者两个链表之间移动数据的时候,直接把节点摘下来,接入到新的位置就可以了,效率比较高。splice方法就是将list的元素进行拼接,原理就是改变结点指针的指向,效率比较高。先看看这splice方法的三种声明:(1)voidsplice(iteratorposition,list&lt…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

list容器底层实现是一个带头结点的双向链表,由于链表的每个节点是单独开辟的,所以链表在移动数据,或者两个链表之间移动数据的时候,直接把节点摘下来,接入到新的位置就可以了,效率比较高。
splice方法就是将list的元素进行拼接,原理就是改变结点指针的指向,效率比较高。


先看看这splice方法的三种声明:
(1)void splice ( iterator position, list<T,Allocator>& x );
功能: 将 list x 中的元素全都移到position处
(2)void splice ( iterator position, list<T,Allocator>& x, iterator it );
功能: 将 list x 中的由迭代器it指向的元素移到position处
(3)void splice ( iterator position, list<T,Allocator>& x, iterator first, iterator last );
功能:将 list x 中的从迭代器 first 到迭代器 last 这一段元素移动到position处

注意:position位置的指定只能是调用者容器中的位置,要剪切的元素是list x中元素


下面是测试代码:

#include<iostream>
using namespace std;
#include<algorithm>
#include<list>

int main()
{
	list<int> list1;
	list<int> list2;
	list<int> list3;

	for(int i = 0; i < 10; ++i)
	{
		list1.push_back(i);
	}

	for(int i = 0; i < 20; ++i)
	{
		list2.push_back(i);
	}

	cout << "this is list1 :  "<< endl;
	for_each( list1.begin(), list1.end(), [](int val){cout << val << " ";} );
	cout << endl;

	cout << "this is list2 :  "<< endl;
	for_each( list2.begin(), list2.end(), [](int val){cout << val << " ";} );
	cout<< endl << endl;

	//将 list1中的首元素移到 list1的最后
	list1.splice ( list1.end(), list1, list1.begin() );

	cout << "list1.splice ( list1.end(), list1, list1.begin() );  //将 list1中的首元素移到 list1的最后 " << endl;
	cout << "this is list1 :  "<< endl;
	for_each( list1.begin(), list1.end(), [](int val){cout << val << " ";} );
	cout << endl << endl;

	//将 list2 中的首元素移动到 list2 的最后
	list2.splice ( list2.end(), list2, list2.begin() );

	cout << "list2.splice ( list2.end(), list2, list2.begin() );  //将 list2 中的首元素移动到 list2 的最后" << endl; 
	cout << "this is list2 :  "<< endl;
	for_each( list2.begin(), list2.end(), [](int val){cout << val << " ";} );
	cout<< endl << endl;

	//将list2的所有元素移到list开始的位置
	list1.splice( list1.begin(), list2 );

	cout << "list1.splice( list1.begin(), list2 );  //将list2的所有元素移到list1开始的位置" << endl;	
	cout << "this is list1 :  "<< endl;
	for_each( list1.begin(), list1.end(), [](int val){cout << val << " ";} );
	cout << endl;

	cout << "this is list2 :  "<< endl;
	for_each( list2.begin(), list2.end(), [](int val){cout << val << " ";} );
	cout<< endl << endl;

	//将list从开始的位置移动到list开始的位置
	list2.splice(list2.begin(), list1, list1.begin(), list1.end());

	cout << "list2.splice(list2.begin(), list1, list1.begin(), list1.end());  //将list1从开始的位置到结束位置移动到list2开始的位置" << endl;
	cout << "this is list1 :  "<< endl;
	for_each( list1.begin(), list1.end(), [](int val){cout << val << " ";} );
	cout<< endl;

	cout << "this is list2 :  "<< endl;
	for_each( list2.begin(), list2.end(), [](int val){cout << val << " ";} );
	cout << endl << endl;


	return 0;
}

运行结果:
在这里插入图片描述

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Nginx服务器不支持PATH_INFO的问题及解决办法

    Nginx服务器不支持PATH_INFO的问题及解决办法

    2021年11月6日
    56
  • 进程管理之进程调度「建议收藏」

    进程管理之进程调度「建议收藏」文章目录一、进程调度基础1、进程调度定义2、进程调度目标二、基本调度算法1、先来先服务算法2、时间片轮转算法3、短任务优先算法4、优先级调度算法5、混合调度算法  在多进程并发的环境里,虽然从概念上看,有多个进程在同时执行,但在单个CPU下,在任何时刻只能有一个进程处于执行状态,而其他进程则处于非执行状态。那么问题来了,我们是如何确定在任意时刻到底由哪个进程执行,哪些不执行呢?这就涉及到进程管理…

    2022年9月29日
    2
  • java实现字符串反转(javastring替换字符串)

    目录字符串反转:1,charAt()2,toCharArray()3,reverse()字符串替换:1.replace()2.replaceAll()3.replaceFirst()字符串反转:1,charAt()通过String类的charAt()的方法来获取字符串中的每一个字符,然后将其拼接为一个新的字符串publicstatic…

    2022年4月18日
    41
  • NFV介绍_NFV技术

    NFV介绍_NFV技术转发自:https://zhuanlan.zhihu.com/p/26259440NFV全称是NetworkFunctionVirtualization。这又是一个与网络相关的故事。先来看看NFV的前世今生吧。在NFV之前,NF(NetworkFunction)是一直存在的,网络中,NF可以看成一个个独立的网元,实现着各自的功能。NF以固定的方式连接起来,统一提供的网络功能和服务。随便在网…

    2022年9月10日
    4
  • hostapd安装总结

    hostapd安装总结http://teampal.mc2lab.com/projects/fwn/wiki/SetupHostapd孟宁老师教程中碰到的问题iwlist

    2022年5月22日
    38
  • macos安装svn软件_windows安装svn服务器

    macos安装svn软件_windows安装svn服务器我们都知道在Windows安装SVN客户端一般都用TortoiseSVN,在MACOS上也有一个类似TortoiseSVN的,就是SnailSVNLite,它的操作跟TortoiseSVN很像,关键还是免费的。安装过程:1.从AppStore上下载SnailSVNLite。2.下载完成,打开软件,在【SVN设置】下,看下面提示设置好3个路径①~/.ssh查找对应的文件夹,如…

    2022年10月20日
    4

发表回复

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

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