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

郑州建设网站推广公司晋城做网站的

郑州建设网站推广公司,晋城做网站的,网站的可用性,网站建设方案书阿里云目录 一、介绍 二、list的常用操作 1、构造 2、迭代器 3、元素访问 4、容量操作 一、介绍 std::list文档链接 list是可以在常数范围内在任意位置进行插入和删除的序列式容器#xff0c;并且该容器可以前后双向迭代。list的底层是双向链表结构#xff0c;双向链表中每个…目录 一、介绍 二、list的常用操作 1、构造 2、迭代器 3、元素访问 4、容量操作 一、介绍 std::list文档链接 list是可以在常数范围内在任意位置进行插入和删除的序列式容器并且该容器可以前后双向迭代。list的底层是双向链表结构双向链表中每个元素存储在互不相关的独立节点中在节点中通过指针指向其前一个元素和后一个元素。list与forward_list非常相似最主要的不同在于forward_list是单链表只能朝前迭代已让其更简单高效。与其他的序列式容器相比(arrayvectordeque)list通常在任意位置进行插入、移除元素的执行效率更好。与其他序列式容器相比list和forward_list最大的缺陷是不支持任意位置的随机访问比如要访问list的第6个元素必须从已知的位置(比如头部或者尾部)迭代到该位置在这段位置上迭代需要线性的时间开销list还需要一些额外的空间以保存每个节点的相关联信息(对于存储类型较小元素的大list来说这可能是一个重要的因素)。 void test1() {listint lt;lt.push_back(1);lt.push_back(2);lt.push_back(3);listint::iterator it lt.begin();while (it ! lt.end()){cout *it ;it;}cout endl;for (auto e : lt){cout e ;}cout endl; }int main() {test1();return 0; } 二、list的常用操作 list中的接口比较多此处类似只需要掌握如何正确的使用然后再去深入研究背后的原理已达到可扩展 的能力。以下为list中一些常见的重要接口。 1、构造 构造函数((constructor) 接口说明 list (size_type n,const value_typeval value_type() 构造的list中包含n个值为val的元素 list() 构造空的list list (const listx) 拷贝构造函数 list (Inputlterator first,Inputlterator last) 用[first,last]区间中的元素构造list // list的构造 void TestList1() {listint l1; // 构造空的l1listint l2(4, 100); // l2中放4个值为100的元素listint l3(l2.begin(), l2.end()); // 用l2的[begin(), end()左闭右开的区间构造l3listint l4(l3); // 用l3拷贝构造l4// 以数组为迭代器区间构造l5int array[] { 16,2,77,29 };listint l5(array, array sizeof(array) / sizeof(int));// 列表格式初始化C11listint l6{ 1,2,3,4,5 };// 用迭代器方式打印l5中的元素listint::iterator it l5.begin();while (it ! l5.end()){cout *it ;it;} cout endl;// C11范围for的方式遍历for (auto e : l5)cout e ;cout endl; } int main() {TestList1();return 0; } 2、迭代器 此处大家可暂时将迭代器理解成一个指针该指针指向list中的某个节点。 函数声明 接口说明 begin  end 返回第一个元素的迭代器返回最后一个元素下一个位置的迭代器 rbegin  rend 返回第一个元素的reverse_iterator,即end位置返回最后一个元素下一个位置的 reverse_iterator,即begin位置 // list迭代器的使用 // 注意遍历链表只能用迭代器和范围for void PrintList(const listint l) {// 注意这里调用的是list的 begin() const返回list的const_iterator对象for (listint::const_iterator it l.begin(); it ! l.end(); it){cout *it ;// *it 10; 编译不通过}cout endl; }void TestList2() {int array[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 };listint l(array, array sizeof(array) / sizeof(array[0]));// 使用正向迭代器正向list中的元素// listint::iterator it l.begin(); // C98中语法auto it l.begin(); // C11之后推荐写法while (it ! l.end()){cout *it ;it;}cout endl;// 使用反向迭代器逆向打印list中的元素// listint::reverse_iterator rit l.rbegin();auto rit l.rbegin();while (rit ! l.rend()){cout *rit ;rit;}cout endl; }【注意】 1.begin与end 为正向迭代器对迭代器执行操作迭代器向后移动。 2.rbegin(end) 与rend(begin) 为反向迭代器对迭代器执行操作迭代器向前移动。 3、元素访问 函数声明 接口说明 front 返回list的第一个节点中值的引用 back 返回list的最后一个节点中值的引用 4、容量操作 函数声明 接口说明 empty 检测list是否为空是返回true,否则返回false size 返回list中有效节点的个数 push_front 在list首元素前插入值为val的元素 pop_front 删除list中第一个元素 push_back 在list尾部插入值为val的元素 pop_back 删除list中最后一个元素 insert 在list position 位置中插入值为val的元素 erase 删除list position位置的元素 swap 交换两个list中的元素 clear 清空list中的有效元素 // 打印列表 void PrintList(const listint l) {for (listint::const_iterator it l.begin(); it ! l.end(); it){cout *it ;}cout endl; }// 测试list的插入和删除操作 // 包括push_back/pop_back/push_front/pop_front void TestList3() {int array[] { 1, 2, 3 };listint L(array, array sizeof(array) / sizeof(array[0]));// 在list的尾部插入4头部插入0L.push_back(4);L.push_front(0);PrintList(L);// 删除list尾部节点和头部节点L.pop_back();L.pop_front();PrintList(L); }// 测试list的insert和erase操作 void TestList4() {int array1[] { 1, 2, 3 };listint L(array1, array1 sizeof(array1) / sizeof(array1[0]));// 获取链表中第二个节点auto pos L.begin();cout *pos endl;// 在pos前插入值为4的元素L.insert(pos, 4);PrintList(L);// 在pos前插入5个值为5的元素L.insert(pos, 5, 5);PrintList(L);// 在pos前插入[v.begin(), v.end)区间中的元素vectorint v{ 7, 8, 9 };L.insert(pos, v.begin(), v.end());PrintList(L);// 删除pos位置上的元素L.erase(pos);PrintList(L);// 删除list中[begin, end)区间中的元素即删除list中的所有元素L.erase(L.begin(), L.end());PrintList(L); }// 测试list的resize/swap/clear操作 void TestList5() {// 用数组来构造listint array1[] { 1, 2, 3 };listint l1(array1, array1 sizeof(array1) / sizeof(array1[0]));PrintList(l1);// 交换l1和l2中的元素listint l2;l1.swap(l2);cout l1;PrintList(l1);cout l2;PrintList(l2);// 将l2中的元素清空l2.clear();cout l2.size() endl; }int main() {cout 执行TestList3() endl;TestList3();cout endl;cout 执行TestList4() endl;TestList4();cout endl;cout 执行TestList5() endl;TestList5();return 0; }
http://www.dnsts.com.cn/news/275564.html

相关文章:

  • 站长工具如何使用html编辑器安卓版 中文
  • 做鞋用什么网站好自己注册网站要多少钱
  • 企业网站 asp.net软件营销方案
  • 设计一套企业vi多少钱seo优化师是什么
  • 做网站还有价值吗今天广州新增确诊最新消息
  • 腾讯云网站托管管理咨询公司名字大全
  • 网站开发与推广方向哪个网站可以做面料订单
  • 成品网站建设流程吉林网站开发公司
  • 查找网站备案信息深圳网站建设 湖南岚鸿
  • wordpress 显示置顶文章百度免费优化
  • 南京专业网站制作哪家好建站语言
  • 代码怎么做网站做矿业的郑州公司网站
  • 沈阳网站seo外包手机网站适配
  • 宁波网站建设找哪家好响应式网页设计实例
  • 物流网站平台建设免费的微商加人软件
  • 三亚旅游网站建设长沙关键词优化新报价
  • 深圳查询建设项目规划的网站大庆免费网站建设
  • 手机app制作网站公司注册地址在哪里看
  • 小牛门户网站公司车辆管理系统软件
  • 女人网上量体做衣网站做网站的销售员电话话术
  • 网站开发前端和后端怎么连接帕绍网站建设
  • 控制面板网站网站开发容易吗
  • 长沙医考网站建设公司中国八冶建设集团网站
  • 网站有多难做toxue外贸网
  • 网站设计文档模板h5做的网站
  • 北京网站优化推广分析商服网站模板
  • 湘潭网站建设哪些公司网站多网合一
  • 兰州网站建设招聘如何防止网站被注册
  • 备案网站ip地址莱芜都市网招聘
  • 软件开发网站能做seo吗网站建设就业