当前位置: 首页 > news >正文

C++ list基础概念、list初始化、list赋值操作、list大小操作、list数据插入

list基础概念:list中的每一部分是一个Node,由三部分组成:val、next、prev(指向上一个节点的指针)

list初始化的代码,见下

#include<iostream>
#include<list>using namespace std;void printList(const list<int>& l) {for (list<int>::const_iterator it = l.begin(); it != l.end(); it++) {cout << *it << " ";}cout << endl;
}int main() {// 1 默认构造函数list<int> l1;cout << "l1: ";printList(l1);// 2 初始化列表list<int> l2_1 = { 7,6,5,4,3 };cout << "l2_1: ";printList(l2_1);list<int> l2_2({ 7,5,4,3,2 });cout << "l2_2: ";printList(l2_2);// 3 迭代器list<int> l3(l2_2.begin(), l2_2.end());cout << "l3: ";printList(l3);// 4 全0初始化list<int> l4(8);cout << "l4: ";printList(l4);// 5 初始化a个blist<int> l5(5, 8);cout << "l5: ";printList(l5);// 6 拷贝构造函数list<int> l6(l2_2);cout << "l6: ";printList(l6);return 0;
}

list赋值操作,代码见下

#include<iostream>
#include<list>using namespace std;void printList(const list<int>& l) {for (list<int>::const_iterator it = l.begin(); it != l.end(); it++) {cout << *it << " ";}cout << endl;
}int main() {list<int> l1 = { 5, 6, 7, 3, 1 };list<int> l2;// 1 = l2 = l1;printList(l2);// 2 assign(迭代器)list<int> l3;l3.assign(l1.begin(), l1.end());printList(l3);// 3 assign(初始化列表)list<int> l4;l4.assign({ 5, 9, 1, 2, 4 });printList(l4);// 4 assign(a, b)list<int> l5;l5.assign(5, 4);printList(l5);return 0;
}

list大小操作,代码见下
 

#include<iostream>
#include<list>using namespace std;void printList(const list<int>& l) {for (list<int>::const_iterator it = l.begin(); it != l.end(); it++) {cout << *it << " ";}cout << endl;
}
/*
empty
size
resize
*/
int main() {list<int> l1;cout << "l1.empty() = " << l1.empty() << endl;cout << "l1.size() = " << l1.size() << endl;l1.assign({ 4, 3, 6, 2, 1 });printList(l1);l1.resize(18);cout << "l1.empty() = " << l1.empty() << endl;cout << "l1.size() = " << l1.size() << endl;printList(l1);l1.resize(20, 6);cout << "l1.empty() = " << l1.empty() << endl;cout << "l1.size() = " << l1.size() << endl;printList(l1);l1.resize(1000);l1.resize(7);cout << "l1.empty() = " << l1.empty() << endl;cout << "l1.size() = " << l1.size() << endl;printList(l1);return 0;
}

结果见下,供理解

list数据插入,代码见下:

#include<iostream>
#include<list>using namespace std;void printList(const list<int>& l) {for (list<int>::const_iterator it = l.begin(); it != l.end(); it++) {cout << *it << " ";}cout << endl;
}
/*
push_front
push_back
insert
*/
int main() {list<int> l;//1 push_frontl.push_front(-3);l.push_front(-2);l.push_front(-1);//2 push_backl.push_back(3);l.push_back(2);l.push_back(1);//3 insert(迭代器, 值)list<int>::iterator it = l.begin();it++;l.insert(it, 0);printList(l);//4 insert(迭代器, 数量, 值)it = l.end();--it;l.insert(it, 5, 8);printList(l);//5 insert(迭代器, 迭代器的开始位置, 迭代器的结束位置)it = l.begin();it++;l.insert(it, l.begin(), l.end());printList(l);return 0;
}

运行结果见下,便于理解

相关文章:

  • wordpress 评论邮件通知seo诊断
  • 朝阳公司做网站贵阳网站建设公司
  • 盐城专业做网站平台宣传推广方案
  • 微信网站开发详解键词优化排名
  • 网站制作新技术搜索最全的搜索引擎
  • 外贸行业网站建设公司排名最近三天的新闻热点
  • 云原生架构设计相关原则
  • C++11——智能指针
  • 楼宇自控成智能建筑核心技术,提升节能效率,构筑绿色发展新优势
  • 举例说明MyBatis中逻辑分页的优缺点
  • [onnx 学习记录] 包包含的主要内容
  • python中的时间模块
  • 基于事件驱动型LSTM模型的黄金周收益归因:贸易关税冲击下的5%涨幅量化解析
  • Linux:多线程---初识线程
  • Veeam Backup Replication Console 13 beta 备份 PVE
  • 深入解析Kafka核心参数:buffer_memory、linger_ms与batch_size的优化之道
  • 【基于SpringBoot的图书管理系统】Redis在图书管理系统中的应用:加载和添加图书到Redis,从数据同步到缓存优化
  • 在 Spring Boot 项目中如何合理使用懒加载?
  • Vue 2 混入 (Mixins) 的详细使用指南
  • Vue 3.0中复杂状态如何管理
  • 2025年Google I/O大会上,谷歌展示了一系列旨在提升开发效率与Web体验的全新功能
  • 基于PDF流式渲染的Word文档在线预览技术
  • Qt C++ GUI编程进阶:多窗口交互与事件机制深度解析
  • 基于AOD-Net与GAN的深度学习去雾算法开发
  • 基于机器学习的沪深300指数波动率预测:模型比较与实证分析
  • 【MySQL】分组查询、聚合查询、联合查询