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