坚持c++学习,真正掌握c++(3)

最近学习了c++primer中的第11章的泛型算法,这一章的基础是c++中的容器,但是泛型算法是独立于特定的容器的,这样的算法不会改变容器的大小,这样保证了不管是哪种类型的容器都可以同时调用同一种算法来实现操作。

首先介绍下这些常用的算法的头文件,比较常用的是algorithm,numeric和iterator,最先遇到的函数是find()函数,需要三个参数,前两个是一般的算法函数都需要的,是一对相同类型的迭代器,这两个迭代器规定了操作的范围,常称为输入范围,而第三个参数是所需要查找的元素;第二个函数是accumulate(),这个函数也需要三个参数,前两个参数也是输入范围,第三个参数给定了累加的初始值;书中还介绍了很多其他的函数,例如count_if函数,unique函数,replace_copy函数等等。

学习这些函数我们要谨记的是这些函数都是泛型算法,函数本身不会改变容器的大小,不会删除或者添加元素,函数是独立于特定的容器的,掌握这些函数的一些基本特征,便于记忆。

然后就是既然这些泛型算法的函数不能改变容器的大小,不能删除和添加元素,那么问题来了,加入我们要实现这样的操作怎么办呢?第一种办法是调用容器的成员函数实现这样的功能,或者使用迭代器适配器,也就是迭代器插入器实现这样的操作,插入器分为三种1. back_inserter 2. front_inserter 3. inserter 这三种迭代器插入器的使用是不一样的,back_inserter是利用了在操纵迭代器时调用了容器的push_back成员函数实现元素的插入,同样另外两个也是在操作迭代器时调用了相应的容器的成员函数;

最后学习了流迭代器和反向迭代器,虽然流不是容器,但是标准库中也定义了输入输出流的迭代器,将流和迭代器绑定在一起实现数据的输入输出,记住我们只能从输入流中读取数据和忘输出流中写入数据。

下面以一段代码结束这篇博客:

#include <iostream>
#include <vector>
#include <list>
#include <algorithm>
using namespace std;

bool is2(int);
void main()
{
	int ia[10]={1,5,2,8,2,3,5,2,9,3};
	vector<int> vec(ia,ia+10);
	//find the element of 2, and count how many there are
	vector<int>::size_type count=0;
	vector<int>::iterator ite=vec.begin();
	while((ite=find(ite,vec.end(),2))!=vec.end())
	{
		ite++;
		count++;
	}
	cout<<count<<endl;
	//using count_if to count the quantity of 2
	vector<int>::size_type count1=count_if(vec.begin(),vec.end(),is2);
	cout<<count1<<endl;

	ostream_iterator<int> out_ite(cout," ");
	copy(vec.begin(),vec.end(),out_ite);
	cout<<endl;

	sort(vec.begin(),vec.end());
	copy(vec.begin(),vec.end(),out_ite);cout<<endl;
	vector<int>::iterator end_iter=unique(vec.begin(),vec.end());
	copy(vec.begin(),vec.end(),out_ite);
	cout<<endl;
	vec.erase(end_iter,vec.end());
	copy(vec.begin(),vec.end(),out_ite);
	vec.clear();

	istream_iterator<int> in_iter(cin),eof;
	while(in_iter!=eof)
		vec.push_back(*in_iter++);

}

bool is2(int x)
{
	return x==2;
}

坚持c++学习,真正掌握c++(3)

时间: 2024-10-11 00:58:45

坚持c++学习,真正掌握c++(3)的相关文章

Vue.js学习笔记:属性绑定 v-bind

v-bind  主要用于属性绑定,Vue官方提供了一个简写方式 :bind,例如: <!-- 完整语法 --> <a v-bind:href="url"></a> <!-- 缩写 --> <a :href="url"></a> 绑定HTML Class 一.对象语法: 我们可以给v-bind:class 一个对象,以动态地切换class.注意:v-bind:class指令可以与普通的class特

Java多线程学习(吐血超详细总结)

林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 目录(?)[-] 一扩展javalangThread类 二实现javalangRunnable接口 三Thread和Runnable的区别 四线程状态转换 五线程调度 六常用函数说明 使用方式 为什么要用join方法 七常见线程名词解释 八线程同步 九线程数据传递 本文主要讲了java中多线程的使用方法.线程同步.线程数据传递.线程状态及相应的一些线程函数用法.概述等. 首先讲一下进程和线程

微信小程序学习总结(2)------- 之for循环,绑定点击事件

最近公司有小程序的项目,本人有幸参与其中,一个项目做下来感觉受益匪浅,与大家做下分享,欢迎沟通交流互相学习. 先说一下此次项目本人体会较深的几个关键点:微信地图.用户静默授权.用户弹窗授权.微信充值等等. 言归正传,今天分享我遇到的关于wx:for循环绑定数据的一个tips:  1. 想必大家的都知道wx:for,如下就不用我啰嗦了: <view class="myNew" wx:for="{{list}}">{{item.title}}<view

【安全牛学习笔记】

弱点扫描 ╋━━━━━━━━━━━━━━━━━━━━╋ ┃发现弱点                                ┃ ┃发现漏洞                                ┃ ┃  基于端口五福扫描结果版本信息(速度慢)┃ ┃  搜索已公开的漏洞数据库(数量大)      ┃ ┃  使用弱点扫描器实现漏洞管理            ┃ ╋━━━━━━━━━━━━━━━━━━━━╋ [email protected]:~# searchsploit Usage:

winform学习日志(二十三)---------------socket(TCP)发送文件

一:由于在上一个随笔的基础之上拓展的所以直接上代码,客户端: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using System.Net.Sockets; using Sys

零基础的人该怎么学习JAVA

对于JAVA有所兴趣但又是零基础的人,该如何学习JAVA呢?对于想要学习开发技术的学子来说找到一个合适自己的培训机构是非常难的事情,在选择的过程中总是 因为这样或那样的问题让你犹豫不决,阻碍你前进的步伐,今天就让小编为您推荐培训机构新起之秀--乐橙谷Java培训机构,助力你成就好未来. 选择java培训就到乐橙谷 北京有什么好的Java培训机构?来乐橙谷北京学Java,零基础走起,乐橙谷Java基础班授课老师经验非常丰富,课程内容安排合理,适合于有一点点Java基础甚至一点都不会Java的同学学

最全解析如何正确学习JavaScript指南,必看!

划重点 鉴于时不时,有同学私信问我:怎么学前端的问题.这里统一回复一下,如下次再遇到问我此问题同学,就直接把本文链接地址发给你了. "前端怎么学"应该因人而异,别人的方法未必适合自己.就说说我的学习方法吧:我把大部分时间放在学习js上了.因为这个js的学习曲线,先平后陡.项目实践和练习啥的,我不说了,主要说下工作之外的时间利用问题.我是怎么学的呢,看书,分析源码.个人这几天统计了一下,前端书籍目前看了50多本吧,大部分都是js的.市面上的书基本,差不多都看过. 第一个问题:看书有啥好处

轻松学习C语言编程的秘诀:总结+灵感

目前在准备一套C语言的学习教程,所以我这里就以C语言编程的学习来讲.注意,讲的是"轻松学习",那种不注重方法,拼命玩命的方式也有其效果,但不是我提倡的.我讲究的是在方式方法对头.适合你.减轻你学习负担和心里压力的前提下,才适当的抓紧时间. 因此,探索一种很好的学习方法就是我所研究的主要内容. 众所周知,学习C语言并非易事,要学好它更是难上加难.这和你期末考试背会几个题目的答案考上满分没多大关系,也就是说你考试满分也说明不了你学好.学精通了C语言.那么怎么才算学精通C语言?闭着眼睛对自己

开始我的Python爬虫学习之路

因为工作需要经常收集一些数据,我就想通过学爬虫来实现自动化完成比较重复的任务. 目前我Python的状况,跟着敲了几个教程,也算是懂点基础,具体比较深入的知识,是打算从做项目中慢慢去了解学习. 我是觉得如果一开始就钻细节的话,是很容易受到打击而放弃的,做点小项目让自己获得点成就感路才更容易更有信心走下去. 反正遇到不懂的就多查多问就对了. 知乎上看了很多关于入门Python爬虫的问答,给自己总结出了大概的学习方向. 基础: HTML&CSS,JOSN,HTTP协议(这些要了解,不太需要精通) R

javaweb学习纲要

Java Web  概述 大纲: 1.C/S体系结构 2.B/S体系机构 3.两种体系结构比较 4.主流的Web程序应用平台 5.java web学习路线图 1.C/S体系结构 C/S是Client/Server的缩写,即客户端/服务器结构.在这种结构中,服务器通常采用高性能的PC机或工作站,并采用大型数据库系统(如Oracle或SQL Server),客户端则需要安装专用的客户端软件,如下图所示.这种结构可以充分利用两端硬件环境的优势,将任务合理分配到客户端和服务,从而降低了系统的通讯开销.在