二叉搜索条件
Binary search condition
我总是对二叉搜索算法的状况感到困惑,它在编程竞赛中花费了我很多时间。我的问题是何时使用这些条件中的每一个?
1. while (low < high)
2. while (high - low > 1)
3. while (low <= high)
low
= 解决方案集中的最小值。
high
= 解决方案集中的最大值。
-
while (low < high)
在搜索范围[low, high)
时使用。更新high
时,请使用high = mid
。更新low
时,请使用low = mid + 1
。 -
while (high - low > 1)
在搜索范围(low, high)
时使用。更新high
时,请使用high = mid
。更新low
时,请使用low = mid
。 -
while (low <= high)
在搜索范围[low, high]
时使用。更新high
时,请使用high = mid - 1
。更新low
时,请使用low = mid + 1
。
代码如下:
public class BinarySearch {
public static void main(String[] args) {
Integer[] nums = { 4, 9, 12, 18, 20, 26, 28, 29, 55 };
for (int i = 0; i < nums.length; ++i) {
System.out.println(binarySearch1(nums, nums[i]));
System.out.println(binarySearch2(nums, nums[i]));
System.out.println(binarySearch3(nums, nums[i]));
}
}
public static <T extends Comparable<T>> int binarySearch1(T[] array, T value) {
final int NOT_FOUND = -1;
int low = 0;
int high = array.length;
while (low < high) {
int mid = low + (high - low) / 2;
int comparison = array[mid].compareTo(value);
if (comparison == 0) {
return mid;
} else if (comparison > 0) {
high = mid;
} else {
low = mid + 1;
}
}
return NOT_FOUND;
}
public static <T extends Comparable<T>> int binarySearch2(T[] array, T value) {
final int NOT_FOUND = -1;
int low = -1;
int high = array.length;
while (high - low > 1) {
int mid = low + (high - low) / 2;
int comparison = array[mid].compareTo(value);
if (comparison == 0) {
return mid;
} else if (comparison > 0) {
high = mid;
} else {
low = mid;
}
}
return NOT_FOUND;
}
public static <T extends Comparable<T>> int binarySearch3(T[] array, T value) {
final int NOT_FOUND = -1;
int low = 0;
int high = array.length - 1;
while (low <= high) {
int mid = low + (high - low) / 2;
int comparison = array[mid].compareTo(value);
if (comparison == 0) {
return mid;
} else if (comparison > 0) {
high = mid - 1;
} else {
low = mid + 1;
}
}
return NOT_FOUND;
}
}
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 在没有太多条件句的情况下,我如何避免被零除
- 有根的二进制搜索树.保留与其父级的链接
- 基于多个条件处理地图中的所有元素
- 条件constexpr函数
- 无论条件是否为true,if总是在c++中执行
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 基于模板值的条件变量
- 在C++中搜索嵌套多映射值
- cpp二进制搜索问题,计算给定数组中输入元素的出现次数
- 二进制搜索树叶数问题
- 使用不变量来确定二分搜索中的边界条件
- 根据条件和优先级搜索容器中的项目
- 如何在Char数组中搜索Char在IF条件语句中
- C++,使用自己的条件搜索文件中的字符串
- C++ 具有多个向量条件的二叉搜索
- 具有两个搜索条件的C++关联容器
- 派生类中的搜索函数,循环条件
- 搜索并找到最短的队列,并在某些条件后搜索
- 二叉搜索条件