package com.atguigu.binarysearchnorecursion;
public class BinarySearchNoRecur {
public static void main(String[] args) {
//测试
int[] arr = {1,3, 8, 10, 11, 67, 100};
int index = binarySearch(arr, 100);
System.out.println("index=" + index);//
}
//二分查找的非递归实现
/**
*
* @param arr 待查找的数组, arr是升序排序
* @param target 需要查找的数
* @return 返回对应下标,-1表示没有找到
*/
public static int binarySearch(int[] arr, int target) {
int left = 0;
int right = arr.length - 1;
while(left <= right) { //说明继续查找
int mid = (left + right) / 2;
if(arr[mid] == target) {
return mid;
} else if ( arr[mid] > target) {
right = mid - 1;//需要向左边查找
} else {
left = mid + 1; //需要向右边查找
}
}
return -1;
}
}
class Solution{
public int serch(int[]nums,int target){
int len=nums.length;//判空且长度
if(len==0){
return -1;
int left=0;
int right=len-1;//确认左右边界
while(left <=right){//左边界小于右边界
int mid=(left+right)/2;//中间值
if(nums[mid]==target){//如果中间值等于目的值
return mid;
}else if(nums[mid]<target){
left=mid+1;
}else{
right=mid;
}}
return left;
}
}
}
class Solution {
public int[] searchRange(int[] nums, int target) {
int[] res = {-1, -1};
if (nums == null || nums.length == 0) return res;
int leftMost = findFirstOccurrencePos(nums, target);
if (leftMost == -1) {
return res;
}
int rightMost = findLastOccurrencePos(nums, target);
res[0] = leftMost;
res[1] = rightMost;
return res;
}
private int findFirstOccurrencePos(int[] nums, int target) {
int l = 0, r = nums.length - 1;
while (l + 1 < r) {
int mid = l + (r - l) / 2;
if (nums[mid] >= target) r = mid;
else l = mid;
}
if (nums[l] == target) return l;
if (nums[r] == target) return r;
return -1;
}
private int findLastOccurrencePos(int[] nums, int target) {
int l = 0, r = nums.length - 1;
while (l + 1 < r) {
int mid = l + (r - l) / 2;
if (nums[mid] <= target) l = mid;
else r = mid;
}
if (nums[r] == target) return r;
return l;
}
}