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

大型网站建设方案常见问题延吉做网站

大型网站建设方案常见问题,延吉做网站,大学生网站模板,唐山石家庄做网站哪家好文章目录list的介绍list的使用list的定义方法list迭代器失效问题list插入和删除inserteraselist迭代器的使用begin#xff0c;end 和 rbegin#xff0c;rendlist元素访问front 和 backlist容量控制与数据清理resizeclearlist操作函数spliceremove 和 remove_ifuniquemergerev… 文章目录list的介绍list的使用list的定义方法list迭代器失效问题list插入和删除inserteraselist迭代器的使用beginend 和 rbeginrendlist元素访问front 和 backlist容量控制与数据清理resizeclearlist操作函数spliceremove 和 remove_ifuniquemergereverseassignlist的介绍 1list是可以在常数范围内在任意位置进行插入和删除的序列式容器并且该容器可以前后双向迭代。 2与其他序列容器相比array,vector,dequelist通常可以在任意位置进行插入移除等效率更高。 3与其他序列式容器相比,list和forward_list最大的缺陷就是不支持任意位置的访问比如要访问list的第6个元素必须从已知的位置的位置迭代到目标位置然而迭代的时间复杂度通常为线性开销list还需要一些额外的空间来保存每个结点的相关联信息对于存储类型较小的list来说)。 list的使用 list的定义方法 方法一 listint lt;方法二 构造1个2类型为list 容器。 listint lt1(1,2);方法三 拷贝构造类型为list 的lt1。 listint lt2( lt1);方法四 利用迭代器区间进行构造。 string s(hello c); listcharlt3(s.begin(),s.end()); 方法五 也是迭代器区间构造的一种形式区间为左闭右开。 int arr[] { 1,2,3,4,5 };int sz sizeof(arr) / sizeof(int);listint lt1(arr, arr 2);list迭代器失效问题 void Test1() {int array[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 };listint l(array, arraysizeof(array)/sizeof(array[0]));auto it l.begin();while (it ! l.end()){// erase()函数执行后it所指向的节点已被删除因此it无效在下一次使用it时必须先给 其赋值l.erase(it); it;} }list插入和删除 insert 三种插入方式 方式1 在指定位置前插入一个数。 方式2 在指定位置插入n个数。 方式3 在指定位置插入相同容器而理性的迭代器区间数据左闭右开 int main() {listint lt;lt.push_back(1);lt.push_back(2);lt.push_back(3);listint::iterator pos find(lt.begin(), lt.end(),3 );lt.insert(pos, 0); for (auto e : lt){cout e ;}cout endl; pos find(lt.begin(), lt.end(), 3);lt.insert(pos, 2, 1); //for (auto e : lt){cout e ;}cout endl; vectorint v(3, 8);pos find(lt.begin(), lt.end(), 1);lt.insert(pos, v.begin(), v.end());for (auto e : lt){cout e ;}cout endl; }erase 三种删除方式 方式1 指定目标位置进行删除。 方式2 指定迭代器区间进行删除。 int main() {listint lt;lt.push_back(1);lt.push_back(2);lt.push_back(3);lt.push_back(4);lt.push_back(5);lt.push_back(6);auto pos find(lt.begin(), lt.end(), 2);lt.erase(pos); //删除2位置的结点。for (auto e : lt){cout e ;}cout endl; pos find(lt.begin(), lt.end(), 3);lt.erase(pos, lt.end()); //给定迭代器区间删除3后面的结点。for (auto e : lt){cout e ;}cout endl; return 0; }list迭代器的使用 正向迭代器和反向迭代器的位置是对称的指向的位置相反。 beginend 和 rbeginrend int main() {listint lt{ 1,2,3,4,5 };//正向迭代器遍历容器auto it lt.begin();while (it ! lt.end()){cout *it ;it;}cout endl;auto rit lt.rbegin();while( rit ! lt.rend() ){cout *rit ;rit;}return 0;}list元素访问 由于list和forward_lsit一样都不能随机访问STL中具有获取list首尾元素功能。 front 和 back int main() {listint lt;lt.push_back(0);lt.push_back(1);lt.push_back(2);lt.push_back(3);lt.push_back(4);lt.push_back(5);lt.push_back(6);cout lt.front() endl; //获取list首元素cout lt.back() endl; //获取list尾元素return 0; } list容量控制与数据清理 resize 1: 如果所给的第一个值大于lsit当前的size如果给了第二个值那么多出的size的值就为第二个所给值如果没给编译器就主动调用缺省值一般为0。 2如果所给的值小于list当前的size则lsit当前的size就为这个所给值 int main() {listint lt{ 1,2,23 };for (auto e : lt){cout e ;}lt.resize(7, 6); //多出的size初始值都为6cout endl;for (auto e : lt){cout e ;}lt.resize(1); //list当前只剩下一个sizecout endl;for (auto e : lt){cout e ;} }clear clear用于清空list容器此时list的size为0 int main() {listint lt(3, 2);for (auto e : lt){cout e ;}cout endl; cout lt.size() endl; lt.clear(); for (auto e : lt){cout e ;}cout endl;return 0; }list操作函数 splice list中splice函数用于两个list容器之间的拼接有三种常见拼接方法。 1 将指定容器全部数据拼接到指定位置。 2 将指定容器的某个数据拼接到目标容器的指定位置。 3 将指定容器的某个迭代器区间左闭右开数据拼接到目标容器中。 int main() {listint lt1(1, 1);listint lt2(1, 2);//将lt2拼接到lt1首部。lt1.splice(lt1.begin(), lt2); for (auto e : lt1){cout e ;}cout endl; listint lt3(1, 3);listint lt4(1, 4);//将lt4容器中首位置拼接到目标容器lt3的尾部。lt3.splice(lt3.end(), lt4, lt4.begin()); for(autoe : lt3){cout e ;}cout endl;listint lt5(1, 5);listint lt6(1, 6);//将指定容器lt6的指定迭代器区间内的数据拼接到目标容器lt5的首部lt5.splice(lt5.begin(), lt6, lt6.begin(), lt6.end()); for (auto e : lt5){cout e ;}cout endl;return 0; }remove 和 remove_if remove: 删除容器容器中指定的数据。包括重复项 remove_if 删除容器当中符合条件的数据。 bool test(const int val) {//删除中容器小于3的数。return val 3;} int main() {listint lt1{ 1,2,3,4,5 };lt1.remove_if(test); for (auto e : lt1){cout e ;}listint lt2{ 1,2,3,4,5,6 };//删除list容器中指定元素。lt2.remove(3); for (auto e : lt2){cout e ;}}unique 删除容器中连续的重复元素。 注意 在使用unique去重之前最好先让list排序。 int main() {listint lt1{ 3,1,1,2,3,3,4,5 };//在使用unique之前最好先使用sort排序一下。lt1.sort();lt1.unique();for (auto e : lt1){cout e ;} }merge 将指定容器合并到目标容器中并且合并过后的容器lt1依然为升序类似于归并排序 int main() {listint lt1{ 3,1,1,2,3,3,4,5 };//在使用unique之前最好先使用sort排序一下。listint lt2{ 6,7,8 };lt1.sort();//将lt2有序容器合并到lt1中。lt1.merge(lt2);for (auto e : lt1){cout e ;} }reverse 将容器中所有数据的位置进行逆置。 int main() {listint lt1{ 1,2,3 };lt1.reverse();for (auto e : lt1){cout e ;} }assign 1将指定个数指定内容的分配给容器覆盖分配 2利用迭代器将存储相同数据类型的容器指定迭代器区间进行分配。 int main() {listint lt1{ 1,2,3 };lt1.assign(3, 1);for (auto e : lt1){cout e ;}string s(hello C);listcharlt2;lt2.assign(s.begin(), s.end());for (auto e : lt2){cout e ;} }
http://www.hkea.cn/news/14284510/

相关文章:

  • 我要发布文章到网站上推广 哪些网站最好教育 wordpress模板下载
  • 深圳市哪些公司做网站好行政审批服务中心
  • 机票旅游网站建设下载赶集网招聘最新招聘
  • 济南网站建设推荐q479185700强涵wordpress xmlrpc漏洞
  • 昆明网站制作公司网站制作流程分为哪七步
  • 太原seo快速排名怎么样泉州seo管理
  • 有什么平台可以做网站云商城
  • 优酷专门给马天宇做的网站怎样在手机安装wordpress
  • 站优云seo优化开发助手app下载
  • 一 网站建设管理基本情况目前网站开发怎么兼顾手机
  • wordpress会员制网站wordpress网站主修改
  • 模板网站区别上海高端网站定制
  • 郑州seo招聘网站优化建议怎么写
  • 域名买好后怎么建设网站wordpress系统邮件设置
  • 圣宠宠物网站建设上海贸易公司排名
  • 灰色网站模板wordpress 全宽轮播
  • 护肤网站的功能设计深圳洲聚网站建设
  • 郑州市建设厅网站wordpress 主题大全
  • 成都手机网站开发温州论坛
  • 青岛网页建设网站seo如何做
  • 创新的网站建设龙江外贸“半年报”
  • 哪个行业建设网站的需求多php网站开发软件是什么
  • 建设网站 织梦网站的策划做推广
  • 深圳网站建设的价格wordpress高级插件
  • 简约大气的网站视频网站如何做推广
  • 音乐网站开发环境描述网站设计毕业设计题目
  • 团购网站推广怎么做崇左网页设计
  • ic外贸网站建设wordpress侧边栏添加分类
  • 如何做企业套模网站网站外链发布平台
  • 云南网站公司新乡个人网站建设价格