C++两个区间的比较?——STL之equal()算法和mismatch()算法

news2024/11/19 19:22:12

equal()算法         检验相等性

bool 
equal(InputIterator1 beg,InputIterator1 end,
        InputIterator2 cmpBeg)

bool 
equal(InputIterator1 beg,InputIterator1 end,
        InputIterator2 cmpBeg,BinaryPredicate op)
  • 第一形式判断区间[beg,end)内的元素是否都和“以cmpBeg 开头的区间”内的元素相等
  • 第二形式判断区间[beg,end)内的元素和“以cmpBeg开头的区间”内的对应元素是否都能够使以下二元判断式为true:        op(elem,cmpElem)
  • op在函数调用过程中不应该改变自身状态,并且op不应改动传入的参数
  • 调用者必须确保“以cmpBeg开头的区间”内含足够元素
  • 当序列不相等时,如果想要了解其间的不同,应使用mismatch()算法

下面用一个例子展示equal()算法两种形式的用法。第一次用来判断两个区间的元素是否相等,第二次调用使用一个辅助判断式,检查两个序列中的元素是否具备一一对应的奇偶关系:

#include"algostuff.h"
using namespace std;
bool bothEvenOrodd(int elem1, int elem2)
{
	return elem1 % 2 == elem2 % 2;
}

int main()
{
	vector<int> col1;
	list<int> col2;

	INSERT_ELEMENTS(col1,1,7);
	INSERT_ELEMENTS(col2, 3, 9);
	
	PRINT_ELEMENTS(col1, "col1: ");		//col1: 1 2 3 4 5 6 7
	PRINT_ELEMENTS(col2, "col2: ");		//col2: 3 4 5 6 7 8 9

	//check whether both collection are equal
	if (equal(col1.begin(), col1.end(), col2.begin()))
	{
		cout << "col1==col2" << endl;
	}
	else
	{
		cout << "col1!=col2" << endl;
	}

	//check for corresponding even and odd elements
	if (equal(col1.begin(), col1.end(), col2.begin(), bothEvenOrodd))
	{
		cout << "even and odd elements correspond" << endl;
	}
	else
	{
		cout << "even and odd elements do not correspond" << endl;
	}
}

mismatch()算法        搜寻第一处不同点

pair<InputIterator1,InputIterator2>
mismatch(InputIterator1 beg,InputIterator1 end,
        InputIterator2 cmpBeg)


pair<InputIterator1,InputIterator2>
mismatch(InputIterator1 beg,InputIterator1 end,
        InputIterator2 cmpBeg,
        BinaryPredicate op)
  • 第一形式返回区间[beg,end)和“以cmpBeg开头的区间”之中第一组两两相异的对应元素
  • 第二形式返回区间[beg,end)和“以cmpBeg开头的区间”之中第一组“使以下二元判断式为false”的对应元素:        op(elem,cmpElem)
  • 如果没有找到相异点,就返回一个pair,以end和第二序列的对应元素组成。这并不意味着两个序列相等,因为第二个序列可能包含较多的元素
  • op在函数调用过程中不应该改变自身状态,并且op不应改动传入的参数
  • 调用者必须确保“以cmpBeg开头的区间”内含足够元素

下面展示这个程序的用法: 

第一次调用mismatch()用以搜寻第一对互异的对应元素,如果找到了就把它们的值写到标准输出装置。第二次调用用来搜寻符合以下条件的第一对元素,“第一序列的元素比第二序列的对应元素大”,找到后返回这两个元素 

#include"algostuff.h"
using namespace std;
int main()
{
	vector<int> col1;
	list<int> col2;

	INSERT_ELEMENTS(col1, 1, 6);
	for (int i = 1; i <= 16; i *= 2)
	{
		col2.push_back(i);
	}
	col2.push_back(3);
	PRINT_ELEMENTS(col1, "col1: ");		//col1: 1 2 3 4 5 6
	PRINT_ELEMENTS(col2, "col2: ");		//col2: 1 2 4 8 16 3

	//find first mismatch
	pair<vector<int>::iterator, list<int>::iterator> values;
	values = mismatch(col1.begin(), col1.end(), col2.begin());
	if (values.first == col1.end())
	{
		cout << "no mismatch" << endl;
	}
	else
	{
		cout << "first mismatch: "
			<< *(values.first) << " and " << *(values.second) << endl;
	}

	//find first position where the element of col1 is not less than the corresponding element of col2
	values = mismatch(col1.begin(), col1.end(),		//first range
		col2.begin(),								//second range
		less_equal<int>());							//criterion
	if (values.first == col1.end())
	{
		cout << "always less-or-equal" << endl;
	}
	else
	{
		cout << "not less-or-equal: "
			<< *(values.first) << " and "
			<< *(values.second) << endl;
	}
}

 程序运行结果如下

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/502513.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

mongodb命令使用

查询副本集当前状况(需要将命令行切换到需要查询的副本集中) rs.status() 查询数据库当前情况 sh.status() 查询数据分片情况 db.集合名称.getShardDistribution() 查看集合当前情况 db.集合名称.stats() 查看集合是否开启分片 db.集合名称.stats().sharded 查看mong…

Python网络编程(一)——了解IP和端口的基础知识以及socket的简单实现

系列文章目录 Python网络编程&#xff08;一&#xff09;——了解IP和端口的基础知识以及socket的简单实现 了解IP和端口的基础知识以及socket的简单实现 系列文章目录前言获取本机设备名和IP获取远程设备的IP地址将IPv4地址转换成以十六进制形式表示二进制数据获取端口的服务…

数据结构 -- 共用体Union

在数据结构 -- 结构体Struct一文中详细介绍了结构体的定义以及内存对齐。在C语言中&#xff0c;还有另外一种和结构体非常类似的语法&#xff0c;叫做共用体&#xff08;Union&#xff09;&#xff0c;也称为联合体。它的定义格式为&#xff1a; union 共用体名{成员列表 };1. …

【CVPR红外小目标检测】红外小目标检测中的非对称上下文调制(ACM)

论文题目&#xff1a; Asymmetric Contextual Modulation for Infrared Small Target Detection 红外小目标检测中的非对称上下文调制 红外小目标数据集 目标个数分布&#xff1a;约90%图片中只有一个目标&#xff0c;约10%图片有多个目标&#xff08;在稀疏/显著的方法中&am…

网文助手。

网文助手 简述 网文助手&#xff0c;免费高质量小说资料网站&#xff0c;支持笔记本和手机端&#xff0c;主要有以下功能。 随机生成小说男女姓名&#xff0c;和尊称随机生成地域和势力名称随机生成功法秘籍、招式战技、法宝兵器、丹药和阵法随机生成妖兽、凶地、天材地宝随…

Prometheus监控报警+Grafana loki日志聚合系统

Prometheus监控报警Grafana loki日志聚合系统 参考文档 https://blog.csdn.net/m0_57480266/article/details/121190725?spm1001.2101.3001.6650.1&utm_mediumdistribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-1-121190725-blog-111992382.235%5Ev3…

二十一、线索转换3:线索的备注转化为客户联系人的备注

功能需求 3.线索的备注信息--》客户备注 4.线索的备注---》联系人备注 5.线索市场活动关系---》联系人市场活动关系 流程图 代码实现&#xff1a;线索的备注转化为客户联系人的备注 1.clueRemarkMapper /*** 根据线索id 查询备注2*/List<ClueRemark> selectInitialC…

Windows本地MySQL升级

一、删除原来的MySQL 删除 C:\Programs Files、C:\Programs Files(x86)、C:\ProgramData 中的所有MySQL目录 找到MySQL数据库中的data保存到其他位置&#xff0c;升级后可以恢复数据库数据 【备份数据】 删除注册表中MySQL的信息 计算机\HKEY_LOCAL_MACHINE\SYSTEM\ControlSet…

Py01·环境搭建

Python环境搭建 官网下载python3.7.3&#xff1a;https://www.python.org/downloads/release/python-373/ 配置系统环境变量目录&#xff1a; E:\ldtools\python3.7.3\python.exe E:\ldtools\python3.7.3\Scripts\pip.exe python.exe 运行环境 pip.exe 包管理器 安装mysql环…

TypeScript 最近各版本主要特性总结

&#xff08;在人生的道路上&#xff0c;当你的期望一个个落空的时候&#xff0c;你也要坚定&#xff0c;要沉着。——朗费罗&#xff09; TypeScript 官网 在线运行TypeScript代码 第三方中文博客 特性 typescript是javascript的超集&#xff0c;向javascript继承额外的编辑…

K8s之Namespace名称空间详解

文章目录 一、名称空间概念二、名称空间基本操作1、创建Namespace的两种方式2、Namespace资源限额 一、名称空间概念 K8s中文手册&#xff1a; K8s名称空间中文官方手册&#xff1a; Kubernetes 支持多个虚拟集群&#xff0c;它们底层依赖于同一个物理集群。 这些虚拟集群被…

UUID使用

1.UUID是什么&#xff1f; UUID 是指&#xff08;Universally Unique Identifier&#xff09;通用唯一识别码&#xff0c;128位。RFC 4122描述了具体的规范实现。 2.UUID解决问题&#xff1f; 分库分表后自增Id重复问题。 3.UUID作用&#xff1f; UUID 的目的是让分布式系…

[数据库系统] 一、创建表以及使用主键约束(educoder)

1.任务&#xff1a;在数据库中创建一个表。 2.需要掌握&#xff1a; 如何在指定数据库中创建表。 知识点&#xff1a;如何在指定数据库中创建表。 我们先来了解一下在数据库中创建表的规则&#xff1a; CREATE TABLE 表名(字段名,数据类型,字段名,数据类型,.....) 例如&…

Oracle 体系结构

文章目录 Oracle体系结构Oracle的内存结构Oracle的进程结构服务器进程后台进程可选后台进程 物理存储结构逻辑存储结构 概念&#xff1a; Oracle server由Oracle instance和Oracle database组成&#xff0c;Oracle instance由后台进程和共享内存组成&#xff0c;Oracle的实例包…

《走进对象村4》之面向对象的第一大特性——封装

文章目录 &#x1f680;文章导读1、封装的概念2、访问限定修饰符3、如何进行封装4、封装的优点&#xff1a; &#x1f680;文章导读 在本篇文章中&#xff0c;将详细的对封装进行总结&#xff0c;文章仅仅是个人的一些理解&#xff0c;如果有错误的地方&#xff0c;还望指出看完…

八岁都能懂:O(N)条件下在N个元素中找出第K小的元素

目录 1 进入情境1-1 金字塔道具1-2 感觉还不够1-3 万能筛子1-4 怎么用呢 2 代码实现2-1 伪代码描述2-2 完整实例c 3 引申3-1 完美的折半舍弃3-2 找出前K小的元素(topK方法&#xff09;3-3 O(n)效率下求中位数参考资料 1 进入情境 生日&#xff0c;朋友送了一堆弹珠&#xff0c;…

[PyTorch][chapter31][卷积]

前言&#xff1a; 卷积神经网络 是 计算机视觉里面应用非常广泛的一个模型。 卷积神经网络 成功案例 人脸识别,指纹识别等应用. 卷积的本质是图像的特征提取&#xff0c; 在冈萨雷士版本《数字图像处理》处理有专门的章节讲解 各种卷积核&#xff0c;在通讯原理里面&#xff0…

MOD09A1、MYD09A1 文件说明

总体介绍 文件全称为 MODIS Terra/Aqua Surface Reflectance 8-Day L3 Global 500 m。文件名称的示例为 “MOD09A1.A2000337.h11v05.005.2006342055602.hdf”。下载下来的 hdf 包括 13 个子数据集&#xff0c;一个 tile 包括 2400*2400 个像元。各数据集的性质如下表所示。 Sci…

51单片机基础实验1

一.51单片机 51单片机&#xff0c;也称为AT89C51&#xff0c;是一种基于Intel 8051架构的8位单片机。它是广泛应用于嵌入式系统和微控制器领域的常见芯片之一。其具有高度灵活性、可编程性和可靠性&#xff0c;因此被广泛应用于各种应用场景中。 51单片机的主要特点包括&…

三十、组播技术——IGMP、IGMP-snooping、PIM-DM、PIM-SM

文章目录 组播概述1、IP组播通信概念2、组播和单播ip地址3、组播MAC4、组播应用场景5、PIM、IGMP、IGMP-snooping 一、IGMP 协议二、PIM DM&#xff08;密集模式&#xff09;1、配置示例如下&#xff1a;2、PIM DM的局限性 三、PM SM&#xff08;稀疏模式&#xff09; 组播概述…