java数组查找

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;

}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值