C++查詢一個數是否在陣列中find用法

雨天吃冰激凌發表於2020-10-21

#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])

相關文章