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

建网站需要什么手续寿光市住房和城乡建设局网站

建网站需要什么手续,寿光市住房和城乡建设局网站,win10优化大师是官方的吗,长沙高端网站建设文章目录 listvectormapset性能比较总结 list 列表&#xff08;list&#xff09;是C STL中的一种容器类型&#xff0c;它是一个双向链表&#xff0c;可以在任意位置高效地添加、删除、移动元素。 以下是一些常用的列表操作&#xff1a; 创建列表 #include <list> std…

文章目录

  • list
  • vector
  • map
  • set
  • 性能比较
  • 总结

list

列表(list)是C++ STL中的一种容器类型,它是一个双向链表,可以在任意位置高效地添加、删除、移动元素。

以下是一些常用的列表操作:

  1. 创建列表
#include <list>
std::list<int> myList;
  1. 添加元素
myList.push_back(1); // 在列表尾部添加元素
myList.push_front(2); // 在列表头部添加元素
myList.insert(myList.begin(), 3); // 在指定位置插入元素
  1. 删除元素
myList.pop_back(); // 删除尾部元素
myList.pop_front(); // 删除头部元素
myList.erase(myList.begin()); // 删除指定位置的元素
  1. 遍历列表
std::list<int>::iterator it;
for(it=myList.begin(); it!=myList.end(); ++it) {std::cout << *it << ' ';
}
  1. 获取列表大小
std::cout << myList.size() << std::endl;
  1. 判断列表是否为空
if(myList.empty()) {std::cout << "List is empty" << std::endl;
}
  1. 清空列表
myList.clear();
  1. 列表排序
myList.sort(); // 默认从小到大排序
myList.sort(std::greater<int>()); // 从大到小排序
  1. 反转列表
myList.reverse();

以上是一些常用的列表操作,更多操作可以参考C++ STL中list的文档。

vector

C++中的vector是STL(标准模板库)中的容器之一,用于存储动态大小的元素序列。

以下是vector的常见操作:

  1. 创建一个空的vector:
   vector<int> vec; // 创建一个空的vector<int>vector<string> strVec; // 创建一个空的vector<string>
  1. 在vector末尾添加元素:
   vec.push_back(1); // 在vector末尾添加一个int类型元素1strVec.push_back("hello"); // 在vector末尾添加一个string类型元素"hello"
  1. 访问vector中的元素:
   int firstElem = vec[0]; // 访问第一个元素string lastElem = strVec.back(); // 访问最后一个元素
  1. 获取vector的大小:
   int size = vec.size(); // 获取vector中元素的个数bool isEmpty = strVec.empty(); // 判断vector是否为空
  1. 删除vector中的元素:
   vec.pop_back(); // 删除vector末尾的一个元素strVec.erase(strVec.begin() + 2); // 删除vector中索引为2的元素
  1. 清空vector中所有元素:
   vec.clear(); // 清空vector中所有元素strVec.resize(0); // 将vector的大小设置为0
  1. 遍历vector中的所有元素:
   for (int i = 0; i < vec.size(); i++) {cout << vec[i] << " ";}for (auto s : strVec) {cout << s << " ";}

第二种方法可以使用C++11中的range-based for循环。

map

C++中的map是STL(标准模板库)中的关联容器之一,用于存储键值对。

以下是map的常见操作:

  1. 创建一个空的map:
   map<string, int> myMap; // 创建一个空的map,键为string类型,值为int类型
  1. 在map中插入键值对:
   myMap.insert(make_pair("apple", 10)); // 在map中插入键为"apple",值为10的键值对myMap["banana"] = 20; // 在map中插入键为"banana",值为20的键值对
  1. 访问map中的元素或查找键:
   int value = myMap["apple"]; // 访问键为"apple"的值auto it = myMap.find("banana"); // 查找键为"banana"的迭代器if (it != myMap.end()) {int value = it->second; // 获取迭代器指向的值}
  1. 获取map的大小:
   int size = myMap.size(); // 获取map中键值对的个数bool isEmpty = myMap.empty(); // 判断map是否为空
  1. 删除map中的键值对:
   myMap.erase("apple"); // 删除键为"apple"的键值对auto it = myMap.find("banana");if (it != myMap.end()) {myMap.erase(it); // 删除迭代器指向的键值对}
  1. 清空map中的所有键值对:
   myMap.clear(); // 清空map中的所有键值对
  1. 遍历map中的所有键值对:
   for (auto it = myMap.begin(); it != myMap.end(); it++) {cout << it->first << ": " << it->second << endl;}for (auto elem : myMap) {cout << elem.first << ": " << elem.second << endl;}

第二种方法可以使用C++11中的range-based for循环。

set

C++中的set是STL(标准模板库)中的关联容器之一,用于存储不重复的元素,并按照一定顺序进行排序。

以下是set的常见操作:

  1. 创建一个空的set:
   set<int> mySet; // 创建一个空的set,元素为int类型
  1. 在set中插入元素:
   mySet.insert(10); // 在set中插入元素10mySet.insert(20); // 在set中插入元素20mySet.insert(30); // 在set中插入元素30
  1. 访问set中的元素或查找元素:
   auto it = mySet.find(20); // 查找元素20的迭代器if (it != mySet.end()) {int value = *it; // 获取迭代器指向的值}
  1. 获取set的大小:
   int size = mySet.size(); // 获取set中元素的个数bool isEmpty = mySet.empty(); // 判断set是否为空
  1. 删除set中的元素:
   mySet.erase(20); // 删除元素20auto it = mySet.find(30);if (it != mySet.end()) {mySet.erase(it); // 删除迭代器指向的元素}
  1. 清空set中的所有元素:
   mySet.clear(); // 清空set中的所有元素
  1. 遍历set中的所有元素:
   for (auto it = mySet.begin(); it != mySet.end(); it++) {cout << *it << endl;}for (auto elem : mySet) {cout << elem << endl;}

第二种方法可以使用C++11中的range-based for循环。

性能比较

使用相同的算法,对vector、list和set进行插入数据和删除数据操作

//insert number to list,increasing sort
void insert_l(int arg){list<int>::iterator iter;for(iter = gl.begin();iter!=gl.end();iter++){//ergodic listif(arg<*iter){gl.insert(iter,arg);//insert numberbreak;}}if(iter == gl.end()){gl.push_back(arg);//push back number}
}
//delete number from list
void delete_l(){default_random_engine e1(seed);//new random engine with seedwhile(!gl.empty()){uniform_int_distribution<unsigned> u(0,gl.size()-1);list<int>::iterator iter = gl.begin();//using iteratorfor(int i=0;i<u(e1);i++){iter++;}gl.erase(iter);//delete number}
}

结果

Data SizeVector Time (s)List Time (s)
100000.2812570.527096
500006.79223.2029
10000026.824107.947
15000060.0688333.013
200000106.619807.597

使用set在插入和删除200 000数据总共只用了2.2331秒、而vector用了106.619秒、list用了807.597秒
在这里插入图片描述

总结

vector的遍历性能明显比list要快。这是因为vector的元素是存储在一块连续的内存空间中,可以直接通过指针进行访问。而list的元素是通过链表相互连接起来的,无法直接访问,需要遍历整个链表才能访问某个元素,因此遍历性能相对较低。
vector和list在不同场景下有不同的优劣势,需要根据具体情况选择适合的容器。例如,需要随机访问或者高效的遍历操作时,可以选择vector;需要频繁的插入或者删除操作时,可以选择list。
set是基于红黑树实现的,红黑树是一种自平衡的二叉查找树,它具有快速的插入、删除和查找操作的时间复杂度,因此在处理大量数据时,set的性能表现会更好。

http://www.15wanjia.com/news/188192.html

相关文章:

  • 延安网站设计公司做网站用方正字体可以额的
  • 淘宝的网站建设的目标网络营销专业就业前景
  • p2p网站建设价格丰台网站建设联系方式
  • 网站建设价格多少音乐网站还可以做
  • 永久免费做网站app北京科技网站建设公司
  • 宁夏网站推广离我最近的物流公司
  • 做网站购买服务器多少钱wordpress根据字段判断
  • wordpress 首页评论网站建设小程序开发seo推广
  • 做网站i3够用吗怎么用图片做网站背景图
  • 搭建网站要什么配置企业网站建设兴田德润地址
  • 企业网站如何建设酒店网站开发需求是企业写的吗
  • 网站专栏建设情况网页游戏排行力荐新壹玩
  • 建设培训中心网站网站建设怎么申请域名
  • 做网站什么主题好付费文章 wordpress
  • 如何推广网站网站推广常用方法高埗做网站
  • 个人站长网站应该如何定位s001网站建设设计
  • 在手机上怎么制作网站中文网站建设技术
  • 动易学校网站系统上海外贸网站优化
  • 2023恢复全员核酸百度推广优化师
  • 网站开发流程甘特图h5响应式网站是什么
  • 怎么制作网站二维码用什么编辑wordpress
  • com网站免费注册如何做一个微信公众号
  • dedecms本地调试好的网站怎么上传到服务器国内跨境电商平台排行榜前十名
  • 彩票推广网站如何做建筑公司企业技术负责人岗位职责
  • 免费空间网站php正规电商平台
  • 网站开发 wenzhou石家庄新闻最新
  • 建筑设计门户网站企业网站模板专业网
  • 合肥知名网站制作公司网站统计数据分析
  • 正规网站建设多少钱一级做A网站
  • 网站建设基础资料做网站的公司怎么拓展业务