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

做b2c网站需要多少钱qianhu微建站

做b2c网站需要多少钱,qianhu微建站,企业网站建设 总结,好的网站建设公司概述 map和multimap是C STL中的关联容器,它们存储的是键值对(key-value pairs),并且会根据键(key)自动排序。两者的主要区别在于: map不允许重复的键multimap允许重复的键 本文将详细解析示例代码中涉及的map操作,包括赋值、排…

概述

mapmultimap是C++ STL中的关联容器,它们存储的是键值对(key-value pairs),并且会根据键(key)自动排序。两者的主要区别在于:

  • map不允许重复的键
  • multimap允许重复的键

本文将详细解析示例代码中涉及的map操作,包括赋值排序大小查询删除等核心功能。

1. 头文件与命名空间

#include <iostream>
#include <map>using namespace std;
  • #include <map>:必须包含的头文件,提供mapmultimap的实现
  • using namespace std:使用标准命名空间,避免每次都要写std::

2. 自定义排序规则(仿函数)

class CompareInt {
public:bool operator()(const int& left, const int& right) const {return left > right;  // 降序排序}
};
  • 仿函数(Functor):重载了()运算符的类,可以像函数一样调用
  • 这里实现了降序排序规则,当left > right时返回true
  • 注意operator()应该声明为const,因为它不修改对象状态

3. map的声明与初始化

map<int, string> mapStu;  // 默认less 升序排序
//map<int, string,greater<int>> mapStu;  // greater 降序排序
//map<int, string,CompareInt> mapStu;  // 使用自定义仿函数
  • 默认排序:不指定第三个模板参数时,使用less<Key>,即升序排序
  • 内置排序规则:可以使用greater<Key>实现降序排序
  • 自定义排序:通过传递自定义的仿函数类型作为第三个模板参数

4. 插入元素

mapStu.insert(pair<int, string>(2, "小明"));
mapStu.insert(pair<int, string>(3, "廉颇"));
mapStu.insert(pair<int, string>(1, "妲己"));
mapStu.insert(pair<int, string>(4, "庄周"));
  • insert():插入键值对
  • 使用pair构造键值对,first是键,second是值
  • 插入后元素会根据键自动排序

5. 拷贝构造与赋值

map<int, string> mapB(mapStu);   // 拷贝构造
map<int, string> mapC = mapStu;  // 赋值操作
  • 拷贝构造:创建一个新map并复制所有元素
  • 赋值操作:将已有map的所有元素复制到另一个map
  • 两种方式都会创建与原map完全相同的新容器

6. 元素访问与修改

mapC[3] = "小乔";  // 通过键访问并修改值
  • operator[]:通过键访问对应的值
  • 如果键不存在,会自动插入该键,值为默认构造

7. 交换操作

mapC.swap(mapB);  // 交换两个map的内容
  • swap():高效交换两个map的内容
  • 实际只交换内部指针,不复制元素,时间复杂度O(1)

8. 删除操作

8.1 删除区间元素
map<int, string>::iterator iBegin = mapB.begin();
++iBegin;
map<int, string>::iterator iEnd = mapB.end();
mapB.erase(iBegin, iEnd);  // 删除[iBegin, iEnd)区间
  • erase(beg, end):删除迭代器区间[beg, end)内的元素
  • 区间是半闭半开的,包含beg但不包含end
  • 返回void(新标准返回下一个元素的迭代器)
8.2 删除单个元素
mapC.erase(mapC.begin());  // 删除第一个元素
mapC.erase(4);             // 删除键为4的元素
  • erase(pos):删除迭代器pos指向的元素
  • erase(key):删除所有键等于key的元素(对于map最多一个)
8.3 清空容器
mapC.clear();  // 清空所有元素
  • clear():删除容器中的所有元素,使size为0
8.4 删除结果检查
map<int, string, greater<int>>::size_type st = mapStu.erase(5);
cout << "st = " << st << endl;  // 输出删除的元素个数
  • **erase(key)**返回删除的元素个数
  • 对于map,返回值只能是0或1
  • 对于multimap,返回值可以是任意非负整数

9. 大小查询

if (!mapC.empty()) {cout << "mapC的大小: " << mapC.size() << endl;
}
  • empty():检查容器是否为空
  • size():返回容器中元素的个数
  • 通常先检查empty()再调用size()更安全

10. 迭代器遍历

for (map<int, string, CompareInt>::iterator it = mapStu.begin(); it != mapStu.end(); it++) {cout << "key: " << (*it).first << "  value: " << (*it).second << endl;
}
  • begin()/end():获取首元素和尾后迭代器
  • 迭代器解引用得到pair<const Key, Value>
  • 可以用it->firstit->second访问键和值

完整代码回顾

#include <iostream>
#include <map>using namespace std;// 仿函数用于比较int(降序排序)
class CompareInt {
public:bool operator()(const int& left, const int& right) const {return left > right;    // 降序排序}
};int main(void) {map<int, string> mapStu;  // 默认less 升序排序//map<int, string,greater<int>> mapStu;  // greater 降序排序// 使用自定义的仿函数作为比较器//map<int, string,CompareInt> mapStu;  mapStu.insert(pair<int, string>(2, "小明"));mapStu.insert(pair<int, string>(3, "廉颇"));mapStu.insert(pair<int, string>(1, "妲己"));mapStu.insert(pair<int, string>(4, "庄周"));// map对象的拷贝构造与赋值map<int, string> mapB(mapStu);   // 拷贝构造for (map<int, string>::iterator it = mapB.begin(); it != mapB.end(); it++) {cout << "key: " << (*it).first << "  value: " << (*it).second << endl;}cout << endl;map<int, string> mapC = mapStu;  // 赋值for (map<int, string>::iterator it = mapC.begin(); it != mapC.end(); it++) {cout << "key: " << (*it).first << "  value: " << (*it).second << endl;}cout << endl;mapC[3] = "小乔";mapC.swap(mapB);// map的删除map<int, string>::iterator iBegin = mapB.begin();++iBegin;map<int, string>::iterator iEnd = mapB.end();mapB.erase(iBegin, iEnd);  // 删除区间mapC.erase(mapC.begin());  // 删除第一个元素mapC.erase(4);             // 删除key为4的元素mapC.clear();              // 清空容器map<int, string, greater<int>>::size_type st = mapStu.erase(5);cout << "st = " << st << endl;  // 输出删除个数// map的大小if (!mapC.empty()) {cout << "mapC的大小: " << mapC.size() << endl;}// 遍历mapfor (map<int, string, CompareInt>::iterator it = mapStu.begin(); it != mapStu.end(); it++) {cout << "key: " << (*it).first << "  value: " << (*it).second << endl;}system("pause");return 0;
}
http://www.dtcms.com/wzjs/507496.html

相关文章:

  • 娄底网站制作公司网站建设平台
  • 软件公司网站模板图片西安seo培训学校
  • 天津做网站哪家公司好网络营销有哪些特点
  • 做类似慕课网的网站要多少钱上海百度推广排名优化
  • 兴宁市住房和城乡建设部网站旅行网站排名前十名
  • 网站pv访问量统计怎么做农村电商平台
  • 打开网站说建设中是什么问题?上海疫情突然消失的原因
  • 观音桥网站建设网站建设百度浏览器官网下载
  • 哈尔滨最新疫情轨迹公布而的跟地seo排名点击软件
  • 网站流量提供商市场营销方案
  • 织梦cms发布侵权网站清单百度关键词优化大师
  • 西宁做网站制作的公司哪家好百度网盘官网
  • 有赞微商城下载搜索引擎优化英文简称
  • 工信部网站 备案网站推广四个阶段
  • 网站流量攻击软件chrome官网
  • 山东做网站费用保定seo推广外包
  • 做网站犯法了 程序员有责任吗专业黑帽seo
  • 互联网服务杭州seo网站建设
  • 青海微信网站建设网站要怎么创建
  • 自己建设一个网站步骤南昌seo排名优化
  • 武汉网站推广优化公司南昌seo排名扣费
  • 有谁知道知乎网站是谁做的拓客软件排行榜
  • 四川企业高端网站建设html期末大作业个人网站制作
  • 微页制作网站模板下载软件短期培训就业学校
  • app开发外包网优化网站软文
  • 有免费注册网站吗百度推广怎么开户
  • 三只松鼠的网站建设理念重庆seo全网营销
  • 网站飘动广告代码关键词搜索工具app
  • 淘宝客商品推广网站建设免费网站开发平台
  • 做网站要固定ip东营网站seo