list类型的用法(含列表合并)

2023-11-19

编程中对于链表的处理通常都是比较麻烦的。C++的STL库中提供了list类型,大大方便了我们对链表的处理。不熟悉的小伙伴们快来了解,一定能为你的编程带来益处。

list是双向带头循环链表,不同于之前讲过的vector,它不支持随机访问(即下标访问)。使用list类型需包含头文件<list>。

list的一些常用函数(以List为例):

1、创建: list<类型>List

2、创建迭代器:list<类型>::iterator pos   

3、头尾插入:

头插入:List.push_front(x)

尾插入:List.push_back(x)

4、中间插入:List.insert(pos,x)     //在pos位置处插入x

5、头尾删除:

头删除:List.pop_front(x)

尾删除:List.pop_front(x)

6、多项删除:List.erase(pos1,pos2)   //删除pos1~pos2之间的元素

7、求List的大小:List.empty()、List.size()

8、列表排序:List.sort()(升序排列)

9、列表交换:List1.swap(List2)

10、清空列表:List.clear()

列表合并(merge)

List1.merge(List2)  //将列表List1、List2合并,List2变为空

列表合并是我要讲的一个重点。对于一般的只含数字的两个列表,使用sort分别对其升序排列后(这是必须的一步),便可以使用merge进行合并。但我在合并结构体类型的列表时,却发现总是报错,查寻了大量资料后,我终于发现了问题。对结构体类型必须先在内部重载 "<",之后才可以正常使用merge进行合并。

这是我当时碰到的问题和解决的代码:

问题:已有a、b两个链表,每个链表中的结点包括学号、成绩。要求把两个链表合并,按学号升序排列。

代码:

# include <iostream>
# include <list>
using namespace std;
typedef struct Student {
	int sno;
	float score;
	bool operator < (const Student& c) const //必须重载小于运算符,以对结构体直接排序  
	{
		return(sno < c.sno);    
	}
}STUD;
int main()
{
	int N, M;
	STUD s;
	list<STUD>mylist1;   //定义STUD类型的链表
	list<STUD>mylist2;
	cin >> N >> M;
	for (int i = 0; i < N; i++) {
		cin >> s.sno >> s.score;
		mylist1.push_back(s);   //在尾部插入新元素
	}
	for (int i = 0; i < M; i++) {
		cin >> s.sno >> s.score;
		mylist2.push_back(s);
	}
	mylist1.sort();
	mylist2.sort();    //使用merge需先对mylist1和mylist2进行相同规则的排序
	mylist1.merge(mylist2);  //把链表mylist1和mylist2合并,mylist2变为空
	list<STUD>::iterator p;  //定义list类型的迭代器
	for (p = mylist1.begin(); p != mylist1.end(); p++) {   //使用迭代器遍历列表并输出
		cout << p->sno << " " << p->score << endl;
	}
	return 0;
}

输入:

2 3
5 100
6 89
3 82
4 95
2 10

输出:

2 10
3 82
4 95
5 100
6 89

以上,是我的个人总结,感谢大家浏览。如果喜欢,还请点个赞,也算是对我这个新手的一点鼓励。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

list类型的用法(含列表合并) 的相关文章

随机推荐

  • 成功上岸字节35K,技术4面+HR面,耗时20天,真是不容易

    这次字节的面试 给我的感触很深 意识到基础的重要性 一共经历了五轮面试 技术4面 HR面 下面看正文 本人自动专业毕业 压抑了五个多月 终于鼓起勇气 去字节面试 下面是我的面试过程 很多面试题 都是靠记忆写的 希望能帮助到大家 致那些努力的
  • 初步认识操作系统(Operator System)

    操作系统 一 冯诺依曼体系结构 内存的重要作用 二 操作系统的概念 三 设计操作系统的目的 三 操作系统在计算机体系中的定位 四 操作系统是如何进行管理的 一 冯诺依曼体系结构 在众多计算机相关的书籍中 不得不提的就是冯诺依曼体系结构 冯诺
  • 无需魔法三分钟上线Midjourney应用,【附源码】【示例】

    ps 我是标题党 目前还没见过三分钟完成任务的 三分钟只能打通Midjourney接口 我花了一天时间接入应用哈哈哈 首先 我要感谢laf赞助我 让我可以免费使用Midjourney进行开发和测试 来自白嫖党的快乐 其次 我要感谢白夜 米开
  • Linux驱动编程(总线设备驱动模型)

    一 驱动编写的3种方法 1 传统写法 使用哪个引脚 怎么操作引脚 都写死在代码中 最简单 不考虑扩展性 可以快速实现功能 修改引脚时 需要重新编译 2 总线设备驱动模型 引入 platform device platform driver
  • 最近opencv又报了啥错(一)

    前言 别骂了别骂了 太久没打python 手贼生 最近在搞opencv和一些ocr 报了一堆错 有些是python的原生错误 有的是opencv的 有的是我nt 就全部记录一下吧 1 bad argument type for built
  • 端口监控信息

    netstat nlptu grep 8080 一 0 0 0 0 8080 代表8080端口 对内网和外网都是开放的 tcp 0 0 0 0 0 0 8080 0 0 0 0 LISTEN 123941 java 二 查看网卡的代码 da
  • KVM中使用usb设备

    进来学习usb驱动 看到网上都在分析usb skeleton c的驱动框架 就想对其调试一下 看一下其函数调用流程 要想调试usb skeleton 首先需要kvm能够探测到usb设备 其次 在kvm中编译usb skeleton c 最后
  • 深度学习要学多久?半年能入门深度学习吗?

    深度学习的学习时间因个人背景 目标和学习方法而异 不同人可能需要不同的时间来掌握深度学习 深度学习要学多久 通常情况下 入门深度学习可能需要几个月的时间 如果你已经有相关背景知识 学习进度可能会更快 以下是一些因素 可以影响学习深度学习所需
  • 解一元二次方程-Java语言实现

    前言 高考完的那个暑假我就开始自学C语言 那时候通过看视频和 C primer plus 写了一个解一元二次方程的程序 从此走上了吊打大学同班同学的路 但是那次是用C语言写的 如今白云苍狗 我已经不是曾经的那个我了 但我还是一如既往的废物
  • Java的内省技术

    什么是内省 在计算机科学中 内省是指计算机程序在运行时 Run time 检查对象 Object 类型的一种能力 通常也可以称作运行时类型检查 不应该将内省和反射混淆 相对于内省 反射更进一步 是指计算机程序在运行时 Run time 可以
  • 大数据面试-03-大数据工程师面试题

    2 13 简述hadoop的调度器 FIFO schedular 默认 先进先出的原则 Capacity schedular 计算能力调度器 选择占用最小 优先级高的先执行 依此类推 Fair schedular 公平调度 所有的job具有
  • 三十三.二叉树的创建、后序遍历、深度统计。

    include
  • 【视频编码学习】VTM15.0编译运行

    VTM版本 15 0 操作系统 Win10 x64位 IDE Visual Studio 2019 编译器 cmake 利用VS2019运行VTM15 0 前言 一 下载VTM15 0 二 下载安装cmake 1 下载cmake并安装 2
  • Java中的IO流如何理解——精简

    目录 引言 缓冲流 字节缓冲流 字符缓冲流 转换流 字符输入转换流 字符输出转换流 序列化和反序列化 对象序列化 对象反序列化 打印流 Properties 引言 通过前面的简单学习 我们已经能够大致了解了关于文件的操作 但是能够明显感受到
  • mybatis中pagehelper分页、排序

    原文链接 https blog csdn net liuyuanjiang109 article details 78955881 在springboot 结合mybatis 时用到pagehelper 分页工具 并进行分页 排序 其git
  • 安装 mysqldb for python

    1 安装 ssetuptools wget http pypi python org packages 2 6 s setuptools setuptools 0 6c9 py2 6 egg md5 ca37b1ff16fa2ede6e19
  • 常用GIT命令速览,现学也能登堂入室

    系列文章目录 手把手教你安装Git 萌新迈向专业的必备一步 GIT命令只会抄却不理解 看完原理才能事半功倍 常用GIT命令速览 现学也能登堂入室 系列文章目录 一 GIT HELP 1 命令文档 2 简要说明 二 配置 config 1 配
  • minio上传文件报错io.minio.errors.InvalidResponseException: Non-XML response from server

    上传文件报错io minio errors InvalidResponseException Non XML response from server 开发中上传文件到minio遇到问题 上传小于1M的文件成功 上传大于1M的文件失败 检查
  • 《算法图解》第九章动态规划学习心得

    1 背包问题 动态规划先解决子问题 再逐步解决大问题 每个动态规划都从一个网格开始 背包问题的网格如下 网格最初是空的 动态规划就是逐步将网格填满 吉他行 第一个单元格表示背包的容量为1磅 吉他的重量也是1磅 这意味着它能装入背包 因此这个
  • list类型的用法(含列表合并)

    编程中对于链表的处理通常都是比较麻烦的 C 的STL库中提供了list类型 大大方便了我们对链表的处理 不熟悉的小伙伴们快来了解 一定能为你的编程带来益处 list是双向带头循环链表 不同于之前讲过的vector 它不支持随机访问 即下标访