STL 链表(list)的使用

本文通过一个C++程序示例介绍了STL中链表(list)的基本使用方法,包括链表的创建、元素的增删改查、排序、反转等操作,并展示了如何通过成员函数实现这些功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简介

链表(list)是STL所提供的一种序列化容器,可实现双向遍历,但是无法提供随机访问。链表的一个优点是无论在任何位置添加、删除元素所需的时间均为常量。


代码示例

/*************************/
/* ListTest.cpp          */
/*************************/
#include <iostream>
#include <list>

typedef std::list<int> IntList;

// 打印.
static void PrintIntList(IntList& intList, const char * szName);

int main(int argc, char *argv[])
{
	int i;

	// 几种不同构造方式.
	IntList list_1;
	IntList list_2(8, 2);
	IntList list_3(list_2);
	IntList list_4(list_3.begin(), list_3.end());

	// 打印.
	PrintIntList(list_1, "list_1");
	PrintIntList(list_2, "list_2");
	PrintIntList(list_3, "list_3");
	PrintIntList(list_4, "list_4");

	std::cout<<std::endl<<"初始化链表..."<<std::endl;
	for(i=5; i>=0; --i)
	{
		list_1.push_front(i);
	}
	for(i=6; i<10; ++i)
	{
		list_1.push_back(i);
	}
	PrintIntList(list_1, "list_1");

	std::cout<<std::endl<<"反转链表..."<<std::endl;
	list_1.reverse();
	PrintIntList(list_1, "list_1");

	std::cout<<std::endl<<"加入重复元素到链表中..."<<std::endl;
	list_1.push_back(5);
	PrintIntList(list_1, "list_1");

	std::cout<<std::endl<<"对链表排序..."<<std::endl;
	list_1.sort();
	PrintIntList(list_1, "list_1");

	std::cout<<std::endl<<"对链表去重..."<<std::endl;
	list_1.unique();
	PrintIntList(list_1, "list_1");

	std::cout<<std::endl<<"删除链表末位元素..."<<std::endl;
	list_1.pop_back();
	PrintIntList(list_1, "list_1");

	std::cout<<std::endl<<"删除链表首位元素..."<<std::endl;
	list_1.pop_front();
	PrintIntList(list_1, "list_1");

	i = 9527;
	std::cout<<std::endl<<"删除链表中值为"<<i<<"的元素..."<<std::endl;
	list_1.remove(i);
	PrintIntList(list_1, "list_1");

	i = 6;
	std::cout<<std::endl<<"删除链表中值为"<<i<<"的元素..."<<std::endl;
	list_1.remove(i);
	PrintIntList(list_1, "list_1");

	i = 4;
	std::cout<<std::endl<<"重定义链表长度为"<<i<<"..."<<std::endl;
	list_1.resize(i);
	PrintIntList(list_1, "list_1");

	std::cout<<std::endl<<"粘接链表..."<<std::endl;
	list_1.splice(list_1.end(), list_2, list_2.begin(), list_2.end());
	PrintIntList(list_1, "list_1");

	std::cout<<std::endl<<"清空链表..."<<std::endl;
	list_1.clear();
	PrintIntList(list_1, "list_1");
	std::cout<<"链表是否为空:"<<list_1.empty()<<std::endl;

	return 0;
}

void PrintIntList(IntList& intList, const char * szName)
{
	std::cout<<"["<<szName<<"]: ";

	std::copy(intList.begin(), intList.end(),
		std::ostream_iterator<int>(std::cout, " "));

	std::cout<<std::endl;
}


运行结果:



==============================End=================================

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值