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

配送系统网站怎么做设计理念简短范文

配送系统网站怎么做,设计理念简短范文,专业的南昌网站建设,制作的网站图片不显示目录 前言一#xff0c;list的介绍二#xff0c;list的基本使用2.1 list的构造2.2 list迭代器的使用2.3 list的头插#xff0c;头删#xff0c;尾插和尾删2.4 list的插入和删除2.5 list 的 resize/swap/clear 前言 list中的接口比较多#xff0c;与string和vector类似list的介绍二list的基本使用2.1 list的构造2.2 list迭代器的使用2.3 list的头插头删尾插和尾删2.4 list的插入和删除2.5 list 的 resize/swap/clear 前言 list中的接口比较多与string和vector类似只需要掌握如何正确的使用然后再去深入研究背后的原理已达到可扩展的能力。本文只介绍list中一些常见的重要接口。 注意使用list时需要包含头文件 list 。 一list的介绍 list是可以在常数范围内在任意位置进行插入和删除的序列式容器并且该容器可以前后双向迭代。list的底层是双向链表结构双向链表中每个元素存储在互不相关的独立节点中在节点中通过指针指向 其前一个元素和后一个元素。list与forward_list非常相似最主要的不同在于forward_list是单链表只能朝前迭代已让其更简单高 效。与其他的序列式容器相比(arrayvectordeque)list通常在任意位置进行插入、移除元素的执行效率 更好。与其他序列式容器相比list和forward_list最大的缺陷是不支持任意位置的随机访问比如要访问list 的第6个元素必须从已知的位置(比如头部或者尾部)迭代到该位置在这段位置上迭代需要线性的时间开销list还需要一些额外的空间以保存每个节点的相关联信息(对于存储类型较小元素的大list来说这可能是一个重要的因素) 二list的基本使用 2.1 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; }2.2 list迭代器的使用 string和vector的是随机迭代器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)为反向迭代器对迭代器执行操作迭代器向前移动 2.3 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); }2.4 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); }2.5 list 的 resize/swap/clear // 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);PrintList(l1);PrintList(l2);// 将l2中的元素清空l2.clear();cout l2.size() endl; }
http://www.tj-hxxt.cn/news/136208.html

相关文章:

  • 网站规划项目与设计实例创意设计图案
  • 电子商务网站建设课seo技术推广
  • 有哪些学校的网站做的好处怎样批量做地级市网站
  • wordpress页面专题长沙官网seo分析
  • 哪些因素营销网站权重石家庄关键词搜索引擎优化
  • 洛阳瀍河建设局网站wordpress修改地址后
  • 芜湖网站建设全包仅需800元坪地网站建设如何
  • 网站的访问量怎么查网站建设学习
  • 小企业建站系统跨境电商那个网站做饰品比较好
  • 新区seo整站优化公司下载wix做的网站
  • 白酒网站模版响应式网站 图片居中
  • 建设部职称评审的网站免费信息发布网站大全
  • 长沙市天心区城乡建设局网站vue.js网站开发用例
  • wordpress子目录建站怎么选择主题移动端网站开发流程图
  • 现在主流的网站开发语言北京小程序制作实惠华网天下
  • 网站建设 产品拍照问卷调查网站怎么做
  • 一流的网站建设建设 银行网网站
  • 上海人才网欢迎您成都网站seo厂家
  • 手机网站建设ppt做网站用windows和 linux
  • 做盈利网站怎么备案python wordpress建站
  • 网站轮播图片特效广州做网站好的公司
  • 网站建设教程免费下载中山搜索引擎优化
  • 增城住房和城乡建设局网站泰州百度seo公司
  • 建设机械网站方案网站建设综合实训
  • 江门网站建设公司哪家好企业网站托管方式
  • 七初SEO网站建设珠海做网站的
  • 经营地址怎么在国税网站做更改怎样开通微信小商店
  • 网站开发获取用户微信号登录亚马逊网站做外贸
  • 株洲专业做网站设计的进入百度知道首页
  • 北京新机场建设指挥部网站外网资源