import java.util.*;
/**
面试题:
数组元素查找:
1、普通数组元素查找
2、二分查找
3、面试题:二分查找法运用
4、用java内部函数Arrays.binarySearch数组二分查找,导入模块 import java.util.*;
*/
class Arrayelementfind_1
{
public static void main(String[] args)
{
int[] arr={234,4,5,75,78};
int[] arr2={2,4,5,7,32,42,88};
//int index=getIndex(arr,4);//普通数组元素查找
int index=halfSearch(arr,75);//二分法查找元素
int index2=halfSearch_2(arr,75);//二分法查找元素
int index3=halfSearch_22(arr2,75);//插入元素并返回下标
int index4=Arrays.binarySearch(arr2,42);
int index5=Arrays.binarySearch(arr2,75);
/*使用内部函数Arrays.binarySearch数组二分查找,返回值告诉我们这个数是否是数组中已经存在的和如果不存在应该插入那个位置,
负的插入点减一,相当于halfSearch_22中返还-min-1;
*/
//System.out.println("index="+index);
System.out.println("index2="+index2);
System.out.println("index3="+index3);
System.out.println("index4="+index4);
System.out.println("index5="+index5);
}
/*
数组元素查找
*/
public static int getIndex(int[] arr,int key)
{
for(int x=0;x<arr.length;x++)
{
if(arr[x]==key)
return x;
}
return -1;
}
/*
二分查找法
*/
public static int halfSearch(int[] arr,int key)
{
int min,mid,max;
min=0;
max=arr.length-1;
mid=(min+max)/2;
while(arr[mid]!=key)
{
if(key>arr[mid])
min=mid+1;
else if (key<arr[mid])
max=mid-1;
if(max<min)
return -1;
mid=(min+max)/2;
}
return mid;
}
public static int halfSearch_2(int[] arr,int key)
{
int min,mid,max;
min=0;
max=arr.length-1;
mid=(min+max)/2;
while(min<max)
{
mid=(min+max)>>1;
if(key>arr[mid])
min=mid+1;
else if (key<arr[mid])
max=mid-1;
else
return mid;
}
return -1;
}
/*
面试题:给定一个有序数组,如果往该数组中存储一个元素,并保证这个数组还是有序的,该元素存储的角标如何获取
*/
public static int halfSearch_22(int[] arr,int key)
{
int min,mid,max;
min=0;
max=arr.length-1;
mid=(min+max)/2;
while(min<max)
{
mid=(min+max)>>1;
if(key>arr[mid])
min=mid+1;
else if (key<arr[mid])
max=mid-1;
else
return mid;
}
return min;
}
}
/**
面试题:
数组元素查找:
1、普通数组元素查找
2、二分查找
3、面试题:二分查找法运用
4、用java内部函数Arrays.binarySearch数组二分查找,导入模块 import java.util.*;
*/
class Arrayelementfind_1
{
public static void main(String[] args)
{
int[] arr={234,4,5,75,78};
int[] arr2={2,4,5,7,32,42,88};
//int index=getIndex(arr,4);//普通数组元素查找
int index=halfSearch(arr,75);//二分法查找元素
int index2=halfSearch_2(arr,75);//二分法查找元素
int index3=halfSearch_22(arr2,75);//插入元素并返回下标
int index4=Arrays.binarySearch(arr2,42);
int index5=Arrays.binarySearch(arr2,75);
/*使用内部函数Arrays.binarySearch数组二分查找,返回值告诉我们这个数是否是数组中已经存在的和如果不存在应该插入那个位置,
负的插入点减一,相当于halfSearch_22中返还-min-1;
*/
//System.out.println("index="+index);
System.out.println("index2="+index2);
System.out.println("index3="+index3);
System.out.println("index4="+index4);
System.out.println("index5="+index5);
}
/*
数组元素查找
*/
public static int getIndex(int[] arr,int key)
{
for(int x=0;x<arr.length;x++)
{
if(arr[x]==key)
return x;
}
return -1;
}
/*
二分查找法
*/
public static int halfSearch(int[] arr,int key)
{
int min,mid,max;
min=0;
max=arr.length-1;
mid=(min+max)/2;
while(arr[mid]!=key)
{
if(key>arr[mid])
min=mid+1;
else if (key<arr[mid])
max=mid-1;
if(max<min)
return -1;
mid=(min+max)/2;
}
return mid;
}
public static int halfSearch_2(int[] arr,int key)
{
int min,mid,max;
min=0;
max=arr.length-1;
mid=(min+max)/2;
while(min<max)
{
mid=(min+max)>>1;
if(key>arr[mid])
min=mid+1;
else if (key<arr[mid])
max=mid-1;
else
return mid;
}
return -1;
}
/*
面试题:给定一个有序数组,如果往该数组中存储一个元素,并保证这个数组还是有序的,该元素存储的角标如何获取
*/
public static int halfSearch_22(int[] arr,int key)
{
int min,mid,max;
min=0;
max=arr.length-1;
mid=(min+max)/2;
while(min<max)
{
mid=(min+max)>>1;
if(key>arr[mid])
min=mid+1;
else if (key<arr[mid])
max=mid-1;
else
return mid;
}
return min;
}
}