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

做外贸网站效果好吗开创集团与百度

做外贸网站效果好吗,开创集团与百度,东营网站建设教程,国家市场监督管理总局电话0108865文章目录 一、list 详解1、内存管理2、常用操作3、迭代器erase()删除list中的元素 前言: C 标准模板库(STL)中的 list 容器是一种双向链表数据结构,它允许在常数时间内进行插入和删除操作,而无需重新分配整个容器或移动…

文章目录

  • 一、`list` 详解
    • 1、内存管理
    • 2、常用操作
    • 3、迭代器+erase()删除list中的元素

前言:

C++ 标准模板库(STL)中的 list 容器是一种双向链表数据结构,它允许在常数时间内进行插入和删除操作,而无需重新分配整个容器或移动大量元素list 容器由一系列节点组成,每个节点包含数据部分和指向前后节点的指针,这种结构使得 list 在某些场景下非常高效。本文将重点介绍 list 容器的内存存储机制及其常见用法。

一、list 详解

1、内存管理

list 容器的内存存储特点主要体现在以下几个方面:

  • 非连续存储: 与数组不同,list 的元素不存储在连续的内存块中。每个元素(节点)包含数据部分以及指向前后节点的指针。这种结构使得 list 能够灵活地在任意位置进行插入和删除操作。
  • 动态内存分配: 每次插入新元素时,list 会动态分配新的节点内存。这种机制避免了像 vector 那样在插入或删除元素时可能需要重新分配整个容器的内存,从而减少了内存碎片化的风险。
  • 双向链表: 每个节点包含两个指针,一个指向前一个节点(prev),另一个指向下一个节点(next)。这使得 list 能够在常数时间内向前或向后遍历。

2、常用操作

  • push_back(const T& value) 在 list 的末尾添加一个元素。
  • push_front(const T& value) 在 list 的开头添加一个元素。
  • pop_back() 移除 list 的最后一个元素。
  • pop_front() 移除 list 的第一个元素。
  • insert(iterator pos, const T& value) 在指定位置插入一个元素。
  • erase(iterator pos) 移除指定位置的元素。
  • erase(iterator first, iterator last) 移除指定范围内的元素。
  • clear() 移除 list 中的所有元素。
  • sort() 对 list 进行排序。
  • sort(Compare comp) 使用自定义比较函数对 list 进行排序。
  • reverse():反转 list 中元素的顺序。

3、迭代器+erase()删除list中的元素

std::list 是一个双向链表容器,它提供了 erase 成员函数来删除元素。这个函数接受一个迭代器作为参数,该迭代器指向要删除的元素。调用 erase 后,该元素会从 list 中移除,并且 erase 会返回一个指向被删除元素之后位置的迭代器(如果存在的话;如果删除的是最后一个元素,则返回 end())。

示例:

#include <iostream>  
#include <list>  int main() {  // 创建一个 list 并初始化  std::list<int> myList = {1, 2, 3, 4, 5};  // 打印原始 list  std::cout << "Original list: ";  for (int val : myList) {  std::cout << val << " ";  }  std::cout << std::endl;  // 创建一个迭代器指向要删除的元素(例如,值为 3 的元素)  auto it = std::find(myList.begin(), myList.end(), 3);  // 检查是否找到了该元素  if (it != myList.end()) {  // 删除元素,并获取删除后下一个元素的迭代器  it = myList.erase(it); // 注意:这里我们更新了 it 的值  // 可选:打印删除后的 list  std::cout << "List after erasing 3: ";  for (int val : myList) {  std::cout << val << " ";  }  std::cout << std::endl;  } else {  std::cout << "Element 3 not found in the list." << std::endl;  }  // 注意:如果你不打算使用擦除后返回的迭代器(即不关心擦除后的下一个元素),  // 你也可以不更新 it,但之后不要使用它,因为它现在是一个无效迭代器。  return 0;  
}
http://www.dt0577.cn/news/26580.html

相关文章:

  • 手工活外发加工正规厂家直接发货优化排名案例
  • 北京市朝阳区网站制作公司免费制作个人网站
  • 全球做的比较好的网站做个公司网站大概多少钱
  • 青岛市城市建设委员会网站宁波seo哪家好快速推广
  • 苏州建设网站电话营销策划书案例
  • 做网站找哪家好58同城如何发广告
  • 深圳网站关键词优化新app推广方案
  • 免费平面设计教程全集搜索引擎优化的主要内容
  • 百度网站制作域名注册平台
  • 网站开发及建设费用成全视频免费观看在线看
  • 银川住房城乡建设委官方网站谷歌推广运营
  • 今日头条十大新闻上海广东网站se0优化公司
  • 东莞企业网站建设网站策划是什么
  • 广州 环保 凡人网站建设百度一下你就知道官网
  • asp公司企业网站模板源代码热门网站
  • 网站开发案例详解下载爱奇艺科技有限公司
  • 网站目录怎么做和生活爱辽宁免费下载安装
  • 哪些网站图片做海报好淘宝标题优化工具推荐
  • 电商网站怎么做与众不同网络营销专业可以干什么工作
  • 政府网站建设先进个人典型材料枣庄网站建设制作
  • ppt排版布局哈尔滨seo关键词排名
  • 用网页采集个人信息网站怎么做南昌seo数据监控
  • 上海建设工程交易服务中心网站seo标题是什么意思
  • 目前流行的网站分辨率做多大精准大数据获客系统
  • 网站网络推广服务南宁网络推广外包
  • 国内做设计的网站建设自己做网站需要多少钱
  • 柳市做公司网站seo关键词排名优化怎样收费
  • 12306网站做的真垃圾seo免费推广软件
  • 最新网域查询入口seo搜索推广费用多少
  • 涿州网站制作厦门百度seo公司