C++查找一个数是否在数组中find用法


#include "stdafx.h"

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

int main(){
	int a[]={1,2,3,4,5};
	int b=3;
	if(find(a,a+sizeof(a)/sizeof(a[0]),b)!=a+sizeof(a)/sizeof(a[0])){
	cout<<"yes"<<endl;
	}
	else{
		cout<<"no"<<endl;
	}
	cout<<find(a,a+sizeof(a)/sizeof(a[0]),b)<<endl;
	cout<<a+sizeof(a)/sizeof(a[0])<<endl;
	cout<<a+4<<endl;
	cout<<a<<endl;
	cout<<sizeof(a)<<endl;

	for(int i=0;i<sizeof(a)/sizeof(a[0]);i++){
		cout<<a[i]<<endl;
	}
	system("pause");

}

在这里插入图片描述
在这里可以发现直接输出a为数组首元素的地址在这里是0x00B3F8A0,a+4即为加4个int类型长度,即是加16个字节位0x00B3F8B0,这里sizeof(a)为20,则a+sizeof(a)/sizeof(a[0]=a+5,所以地址为0x00B3F8B4.在这里find也是返回地址值的
00B3F8A8=a+2.
如果find的值不在数组里如

cout<<find(a,a+sizeof(a)/sizeof(a[0]),6)<<endl;

会输出数组最后一个元素后一位的地址即a+5或者a+sizeof(a)/sizeof(a[0])


版权声明:本文为weixin_39289876原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。