STL 查找vector容器中的指定对象:find()与find_if()算法
1 从vector容器中查找指定对象:find()算法
STL的通用算法find()和find_if()可以查找指定对象,参数1,即首iterator指着开始的位置,参数2,即次iterator指着停止处理的地方。注意:包含开始和结束的位置的元素。例子:
#include "stdafx.h"
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int_tmain(int argc, _TCHAR* argv[])
{
vector<char*> fruitVec;
vector<char*>::iterator fruitIt;
fruitVec.push_back("Apple");
fruitVec.push_back("Pineapple");
fruitVec.push_back("Star Apple");
fruitIt= find(fruitVec.begin(),--(fruitVec.end()),"Star Apple");
if(fruitIt == fruitVec.end())
{
cout<<"没找到"<<endl;
}
else
{
cout<<"找到了:"<<*fruitIt<<endl;
}
return 0;
}
执行结果:找到了:Star Apple
2 利用函数对象进行查找:find_if()
#include "stdafx.h"
#include <iostream>
#include <vector>
#include <algorithm>
#include <string>
using namespace std;
classIsTB
{
public:
IsTB(char* pChar,int nLen)
{
cout<<"执行构造函数"<<endl;
m_nLen= nLen;
m_pChar= new char[m_nLen+1];
strcpy(m_pChar,pChar);
}
IsTB(const IsTB& objTB) //需要定义拷贝构造函数
{
cout<<"执行拷贝构造函数"<<endl;
m_nLen= objTB.m_nLen;
m_pChar= new char[m_nLen+1];
strcpy(m_pChar,objTB.m_pChar);
}
bool operator()(const char* pChar)
{
return (strcmp(pChar,m_pChar) == 0);
}
~IsTB()
{
delete m_pChar;
cout<<"执行析构函数"<<endl;
}
public:
char* m_pChar;
int m_nLen;
};
int_tmain(int argc, _TCHAR* argv[])
{
vector<char*> fruitVec;
vector<char*>::iterator fruitIt;
fruitVec.push_back("Apple");
fruitVec.push_back("Pineapple");
fruitVec.push_back("Red Apple");
fruitVec.push_back("Star Apple");
//IsTB objTB("Star Apple",10);//第中方式:先生成对象
//fruitIt = find_if(fruitVec.begin(),fruitVec.end(),objTB);//第中方式,再使用对象
fruitIt= find_if(fruitVec.begin(),fruitVec.end(),IsTB("StarApple",10)); //第一种方式:直接生成临时对象
if(fruitIt == fruitVec.end())
{
cout<<"没找到"<<endl;
}
else
{
cout<<"找到了:"<<*fruitIt<<endl;
}
return 0;
}
第一种方式执行结果:
第2种方式的执行结果:
第2种方式中,执行一次拷贝构造函数我可以理解,但是执行两次,就不理解了。
有理解的麻烦告诉一声,非常感谢。
STL 查找vector容器中的指定对象:find()与find_if()算法的更多相关文章
- STL 统计vector容器中指定对象元素出现的次数:count()与count_if()算法
1 统计vector向量中指定元素出现的次数:count()算法 利用STL通用算法统计vector向量中某个元素出现的次数:count()算法统计等于某个值的对象的个数. #include &quo ...
- 从vector容器中查找一个子串:search()算法
如果要从vector容器中查找是否存在一个子串序列,就像从一个字符串中查找子串那样,次数find()与find_if()算法就不起作用了,需要采用search()算法:例子: #include &qu ...
- 跟我一起学STL(2)——vector容器详解
一.引言 在上一个专题中,我们介绍了STL中的六大组件,其中容器组件是大多数人经常使用的,因为STL容器是把运用最广的数据结构实现出来,所以我们写应用程序时运用的比较多.然而容器又可以序列式容器和关联 ...
- 带你深入理解STL之Vector容器
C++内置了数组的类型,在使用数组的时候,必须指定数组的长度,一旦配置了就不能改变了,通常我们的做法是:尽量配置一个大的空间,以免不够用,这样做的缺点是比较浪费空间,预估空间不当会引起很多不便. ST ...
- vector容器中添加和删除元素
添加元素: 方法一: insert() 插入元素到Vector中 iterator insert( iterator loc, const TYPE &val ); //在指定位置loc前插入 ...
- 如何快速方便的输出向量vector容器中不重复的内容
在vector容器中,存入的内容难免会出现重复,那么如何快速输出或提前非重复的那些数据呢,即重复的数据只输出一次,直观的方法是每次输出都要通过循环比较是否已经输出过,这种方法还是比较费时的,可以利用u ...
- STL之vector容器详解
vector 容器 vector是C++标准模版库(STL,Standard Template Library)中的部分内容.之所以认为是一个容器,是因为它能够像容器一样存放各种类型的对象,简单的说: ...
- [转]STL之vector容器详解
vector 容器 vector是C++标准模版库(STL,Standard Template Library)中的部分内容.之所以认为是一个容器,是因为它能够像容器一样存放各种类型的对象,简单的说: ...
- 【C++】STL,vector容器操作
C++内置的数组支持容器的机制,但是它不支持容器抽象的语义.要解决此问题我们自己实现这样的类.在标准C++中,用容器向量(vector)实现.容器向量也是一个类模板.标准库vector类型使用需要的头 ...
随机推荐
- Android手势操作
xml文件 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:to ...
- sicily 1024 Magic Island
题意:求无向图路径中的最大带权值. 解法:深搜 // Problem#: 9859 // Submission#: 2661875 // The source code is licensed und ...
- C++编程规范之12:懂得何时和如何进行并发性编程
摘要: 如果应用程序使用了多个线程或者进程,应该知道如何尽量减少共享对象,以及如何安全地共享必须共享的对象. 在多线程和并发编程中最重要的是要避免死锁.活锁和恶性的竞争条件. 在编写多线程程序时要注意 ...
- 【Python基础】计算项目代码行数
统计代码行数 # coding: utf-8 import os import sys import time def get_line_count(file_path): ""& ...
- SSO跨域解决方案
单点登录(Single Sign On),简称为 SSO,是目前比较流行的企业业务整合的解决方案之一.SSO的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统.它包括可 以将 ...
- CF 61E 树状数组+离散化 求逆序数加强版 三个数逆序
http://codeforces.com/problemset/problem/61/E 题意是求 i<j<k && a[i]>a[j]>a[k] 的对数 会 ...
- Shell防DDOS攻击原理
#!/bin/sh #date:2015-12-13 #filename:fang-DOS.sh #version:v1.0 while true do #awk '{print $1}' ...
- Spring 详解第一天
spring 框架简述: http://www.cnblogs.com/ToBeAProgrammer/p/5230065.html http://www.cnblogs.com/ToBeAProgr ...
- jquery之鼠标失去焦点事件
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...
- css样式图片、渐变、相关小知识
一,background-position:(图片定位) 三种写法: 1):按%比,左上角最小(0%,0%),右下角最大(100%,%100): 2):(x,y)左上角最小(0,0),右下角最大(ma ...