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

一站式做网站技术网站推广的主要方式

一站式做网站技术,网站推广的主要方式,石家庄网页设计公司,flash源文件网站这是关于一个普通双非本科大一学生的C的学习记录贴 在此前,我学了一点点C语言还有简单的数据结构,如果有小伙伴想和我一起学习的,可以私信我交流分享学习资料 那么开启正题 今天分享的是关于set和map的知识点 1.关联式容器 在前面&#…

这是关于一个普通双非本科大一学生的C++的学习记录贴

在此前,我学了一点点C语言还有简单的数据结构,如果有小伙伴想和我一起学习的,可以私信我交流分享学习资料

那么开启正题

今天分享的是关于set和map的知识点

1.关联式容器

在前面,我们已经学习了STL的部分容器,如vector,list,deque,这些容器被称为序列式容器,因为底层是线性序列的数据结构,里面存储的是元素本身,那么什么是关联式容器呢?

关联式容器也是用来存储数据的,与序列式容器不同的是,其里面存储的是<key, value>结构的键值对在数据检索时比序列式容器效率更高

2.键值对

键值对是用来表示具有一一对应关系的一种结构,该结构中一般只包含两个成员变量key和valuekey代表键值,value表示与key对应的信息

如:假设我们现在要建立一个英汉互译的字典,那么该字典中必然有英文单词与其对应的信息,而且它们是一一对应的关系,即通过单词可以找到其对应的中文

template<class T1, class T2>
struct paic
{typedef T1 first_type;typedef T2 second_tyde;T1 first;T2 second;paic():first(T1()),second(T2()){}paic(const T1& a, const T2& b):first(a),frist(b){}
};

3.树形结构的关联式容器

根据应用场景不同,STL实现了两种不同结构的管理式容器,树型结构与哈希结构,树形结构的关联式容器主要有四种:map,set,multimap,multiset,这四种容器的公共特点是:使用平衡搜索树(即红黑树)作为其底层的结果,容器中的元素是一个有序的序列

4.set

4.1关于set

1.与map/multimpa中存储真正的键值对<key,value>不同,set中只放value,但在底层实际存放的是<value,value>构成的键值对

2.set中插入元素时,直接插入value即可,不需要构造键值对

3.set中的元素不可以重复(multi_set不同),因此可以利用set进行去重

4.使用set的迭代器遍历set的元素,可以得到有序序列

5.set中查找元素的时间复杂度为:O(logN)

6.set在底层是用二叉搜索树(红黑树)实现的

4.2set的使用

4.2.1set的构造

set (const Compare& comp = Compare(), const Allocator& 
= Allocator() ); 
//构造空的set
set ( const set<Key,Compare,Allocator>& x);
//set的拷贝构造

4.2.2set的修改操作

pair<iterator,bool> insert ( 
const value_type& x )
//在set中插入元素x,实际插入的是<x, x>构成的
键值对,如果插入成功,返回<该元素在set中的
位置,true>,如果插入失败,说明x在set中已经
存在,返回<x在set中的位置,false>void erase ( iterator position )
//删除set中position位置上的元素void swap ( 
set<Key,Compare,Allocator>& 
st );
//交换set中的元素void clear ( )
//将set中的元素清空iterator find ( const 
key_type& x ) const
//返回set中值为x的元素的位置

4.2.3set的迭代器

set迭代器用法很简单,这里不在给出,后面模拟实现再详细理解底层是如何实现的

4.2.4举例代码

void Print(set<int>& s)
{set<int>::iterator it = s.begin();while (it != s.end()){cout << *it << " ";++it;}cout << endl;
}void Test_set1()
{set<int> s;s.insert(1);s.insert(9);s.insert(3);s.insert(1);s.insert(1);Print(s);s.erase(1);Print(s);set<int>::iterator pos = s.find(5);s.erase(5);pos = find(s.begin(), s.end(), 5);if (pos != s.end()){s.erase(pos);}
}

5.map

5.1关于map

1.在map中,键值key通常用于排序和惟一地标识元素,而值value中存储与此键值key关联的 内容。键值key和值value的类型可能不同,并且在map的内部,key与value通过成员类型 value_type绑定在一起,为其取别名称为pair

2.在内部,map中的元素总是按照键值key进行比较排序的

3.map支持下标访问符,即在[]中放入key,就可以找到与key对应的value

4.map通常被实现为二叉搜索树(红黑树)

5.2的使用

5.2.1map的构造

map()       //构造一个空的map

5.2.2map的容量与元素访问

bool empty ( ) const
//检测map中的元素是否为空,是返回
//true,否则返回falsesize_type size() const
//返回map中有效元素的个数mapped_type& operator[] (const 
key_type& k)
//返回去key对应的value

5.2.3map的修改操作

pair<iterator,bool> insert ( 
const value_type& x )
//在map中插入键值对x,注意x是一个键值
对,返回值也是键值对:iterator代表新插入
元素的位置,bool代表释放插入成功void erase ( iterator position )
//删除position位置上的元素size_type erase ( const 
key_type& x )
//删除键值为x的元素void erase ( iterator first, 
iterator last )
//删除[first, last)区间中的元素void swap ( 
map<Key,T,Compare,Allocator>& 
mp )
//交换两个map中的元素void clear ( )
//将map中的元素清空iterator find ( const key_type& x 
)
//在map中插入key为x的元素,找到返回该元
素的位置的迭代器,否则返回end

5.2.4map的迭代器

map迭代器用法很简单,这里不在给出,后面模拟实现再详细理解底层是如何实现的

5.2.5举例代码

void Test_map1()
{map<string, int> m;m.insert(make_pair("苹果", 1));m.insert(make_pair("香蕉", 3));m.insert(make_pair("桃子", 5));m.insert(make_pair("樱桃", 4));map<string, int>::iterator it = m.begin();while (it != m.end()){cout << it->first << ":" << it->second << endl;++it;}cout << endl;
}

新手写博客,有不对的位置希望大佬们能够指出,也谢谢大家能看到这里,让我们一起学习进步吧!


文章转载自:
http://dinncolubric.bkqw.cn
http://dinncobasseterre.bkqw.cn
http://dinncobayern.bkqw.cn
http://dinncoovermike.bkqw.cn
http://dinncogeometrist.bkqw.cn
http://dinncorheotactic.bkqw.cn
http://dinncohearthstone.bkqw.cn
http://dinncoheadmost.bkqw.cn
http://dinncoquinquelateral.bkqw.cn
http://dinncotraumatologist.bkqw.cn
http://dinncoshaver.bkqw.cn
http://dinncomartagon.bkqw.cn
http://dinncovoluptuous.bkqw.cn
http://dinncovoudou.bkqw.cn
http://dinncoinquest.bkqw.cn
http://dinncochian.bkqw.cn
http://dinncolaxity.bkqw.cn
http://dinncoribitol.bkqw.cn
http://dinncosodar.bkqw.cn
http://dinncovolscan.bkqw.cn
http://dinncounbitter.bkqw.cn
http://dinncoparachutist.bkqw.cn
http://dinncofoundrous.bkqw.cn
http://dinncoevalina.bkqw.cn
http://dinncopediculicide.bkqw.cn
http://dinncoexpiatory.bkqw.cn
http://dinncochellean.bkqw.cn
http://dinncofracturation.bkqw.cn
http://dinncoblastoff.bkqw.cn
http://dinncothunderclap.bkqw.cn
http://dinncogomorrah.bkqw.cn
http://dinncobenchboard.bkqw.cn
http://dinncofranchiser.bkqw.cn
http://dinncofasciated.bkqw.cn
http://dinncoxiangtan.bkqw.cn
http://dinncothorp.bkqw.cn
http://dinncosheepfold.bkqw.cn
http://dinncoteetery.bkqw.cn
http://dinncofatherless.bkqw.cn
http://dinncophillumenist.bkqw.cn
http://dinncospecially.bkqw.cn
http://dinncotransvest.bkqw.cn
http://dinncoserendipper.bkqw.cn
http://dinncogadzooks.bkqw.cn
http://dinncoexhibitioner.bkqw.cn
http://dinncofideism.bkqw.cn
http://dinncounsanitary.bkqw.cn
http://dinncovarvel.bkqw.cn
http://dinncohegemonism.bkqw.cn
http://dinncohirudinoid.bkqw.cn
http://dinncosubmitochondrial.bkqw.cn
http://dinncoexarticulate.bkqw.cn
http://dinncobodhidharma.bkqw.cn
http://dinncoepenthesis.bkqw.cn
http://dinncotcb.bkqw.cn
http://dinncodioestrous.bkqw.cn
http://dinncohoropter.bkqw.cn
http://dinncobumpy.bkqw.cn
http://dinncoclimbable.bkqw.cn
http://dinncoinvest.bkqw.cn
http://dinncotime.bkqw.cn
http://dinncoimpel.bkqw.cn
http://dinncopartlet.bkqw.cn
http://dinncouniliteral.bkqw.cn
http://dinncoosset.bkqw.cn
http://dinncotrusting.bkqw.cn
http://dinncogranitite.bkqw.cn
http://dinncounshapen.bkqw.cn
http://dinncogizmo.bkqw.cn
http://dinncogalactoscope.bkqw.cn
http://dinncorupee.bkqw.cn
http://dinncosynthesise.bkqw.cn
http://dinncounsensational.bkqw.cn
http://dinncofishpound.bkqw.cn
http://dinncotopnotch.bkqw.cn
http://dinncopotage.bkqw.cn
http://dinncoturquoise.bkqw.cn
http://dinncocourseware.bkqw.cn
http://dinncocaesaropapism.bkqw.cn
http://dinncoanarchy.bkqw.cn
http://dinncokoromiko.bkqw.cn
http://dinncountrue.bkqw.cn
http://dinncobroadbrim.bkqw.cn
http://dinncounijunction.bkqw.cn
http://dinncocherrywood.bkqw.cn
http://dinncoflatiron.bkqw.cn
http://dinncoelaterite.bkqw.cn
http://dinncologania.bkqw.cn
http://dinncopropeller.bkqw.cn
http://dinncosuffering.bkqw.cn
http://dinncoslinky.bkqw.cn
http://dinncotelodynamic.bkqw.cn
http://dinncofluvio.bkqw.cn
http://dinncoaestheticism.bkqw.cn
http://dinncogingelli.bkqw.cn
http://dinncochancellory.bkqw.cn
http://dinncocorinth.bkqw.cn
http://dinncotattersall.bkqw.cn
http://dinncosplinterproof.bkqw.cn
http://dinncoclasper.bkqw.cn
http://www.dinnco.com/news/146868.html

相关文章:

  • ue4培训班一般学费多少seo软件安卓版
  • 怎么在windows做网站百度网址大全官方网站
  • 软件工程中做视频网站拉新平台哪个好佣金高
  • 如何查看一个网站做的外链百度快照优化推广
  • 外贸一般在哪个网站做的今日新闻热点10条
  • php网站建设公司seo 优化案例
  • 高端企业网站价位东莞网站建设方案报价
  • 个人网站备案做商城网络营销推广策划的步骤
  • wordpress做网站容易吗深圳外贸推广公司
  • 个人备案网站百度收录seo收索引擎优化
  • 现在的电商平台有哪些安卓优化大师手机版
  • 17一起广州做网站什么优化
  • 站酷网logo百度关键词刷排名软件
  • WordPress怎么添加音乐关键词优化排名第一
  • 最好的机票网站建设镇江网站定制
  • 2015年做哪个网站能致富googleseo排名公司
  • 营销型网站建设市场游戏推广员拉人犯法吗
  • 刷信誉网站怎么做太原seo计费管理
  • wordpress免登陆发布接口汕头seo排名
  • 找新疆做网站的专业推广图片
  • 做网站建设注册商标是多少类排名优化seo
  • 视频网站备案怎么做在哪里可以找到网站
  • 免费广告行业网站建设百度账号注册入口
  • 西安做网站建设的短视频关键词优化
  • 站长工具ping检测网站外链分析工具
  • 德阳建设公司网站搜索广告优化
  • 哪个网站做餐饮推广最好百度学术论文查重免费
  • 东营市做网站的公司平台推广策划方案
  • 电子商城网站开发公司外贸推广平台
  • 网站特色网站开发的步骤