二分查找(Binary Search)是一种高效的查找算法,它的基本原理是在有序数组中通过不断缩小查找范围来快速定位目标元素。在Java中,二分查找可以通过迭代或递归的方式实现。以下是二分查找的原理以及在Java中的体现:
low和结束索引high,通常初始时low为0,high为数组长度减1。mid,通常使用(low + high) / 2或low + (high - low) / 2来避免整数溢出。high为mid - 1。low为mid + 1。low超过high,表示查找范围为空,查找失败,返回-1或其他表示未找到的值。以下是二分查找的迭代实现和递归实现:
public class BinarySearch {
public static int binarySearch(int[] array, int target) {
int low = 0;
int high = array.length - 1;
while (low <= high) {
int mid = low + (high - low) / 2; // 避免整数溢出
if (array[mid] == target) {
return mid; // 找到目标值,返回索引
} else if (array[mid] < target) {
low = mid + 1; // 在右半部分继续查找
} else {
high = mid - 1; // 在左半部分继续查找
}
}
return -1; // 未找到目标值
}
public static void main(String[] args) {
int[] array = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
int target = 7;
int result = binarySearch(array, target);
System.out.println("Target found at index: " + result);
}
}
public class BinarySearchRecursive {
public static int binarySearch(int[] array, int target, int low, int high) {
if (low > high) {
return -1; // 未找到目标值
}
int mid = low + (high - low) / 2; // 避免整数溢出
if (array[mid] == target) {
return mid; // 找到目标值,返回索引
} else if (array[mid] < target) {
return binarySearch(array, target, mid + 1, high); // 在右半部分继续查找
} else {
return binarySearch(array, target, low, mid - 1); // 在左半部分继续查找
}
}
public static void main(String[] args) {
int[] array = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
int target = 7;
int result = binarySearch(array, target, 0, array.length - 1);
System.out.println("Target found at index: " + result);
}
}
low + (high - low) / 2可以避免整数溢出的问题。通过上述代码和解释,可以看到二分查找在Java中的实现非常直观和高效。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。