全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货

java二分查找算法的例子

发布时间:2023-08-02 10:52:23
发布人:xqq

Java二分查找算法的例子

二分查找算法是一种高效的查找算法,它适用于有序数组或列表。该算法通过将待查找的元素与数组的中间元素进行比较,从而将查找范围缩小一半,直到找到目标元素或确定目标元素不存在为止。下面是一个Java的二分查找算法的例子:

`java

public class BinarySearch {

public static int binarySearch(int[] arr, int target) {

int left = 0;

int right = arr.length - 1;

while (left <= right) {

int mid = left + (right - left) / 2;

if (arr[mid] == target) {

return mid;

} else if (arr[mid] < target) {

left = mid + 1;

} else {

right = mid - 1;

}

}

return -1; // 目标元素不存在

}

public static void main(String[] args) {

int[] arr = {1, 3, 5, 7, 9, 11, 13};

int target = 7;

int result = binarySearch(arr, target);

if (result == -1) {

System.out.println("目标元素不存在");

} else {

System.out.println("目标元素的索引为:" + result);

}

}

`

在上面的例子中,我们定义了一个binarySearch方法,它接受一个有序数组arr和一个目标元素target作为参数。算法使用两个指针leftright来表示查找范围的左右边界。

在每一次循环中,我们计算中间元素的索引mid,然后将目标元素与中间元素进行比较。如果目标元素等于中间元素,则返回中间元素的索引。如果目标元素大于中间元素,则将左边界指针left更新为mid + 1,缩小查找范围到右半部分。如果目标元素小于中间元素,则将右边界指针right更新为mid - 1,缩小查找范围到左半部分。

如果循环结束时仍然没有找到目标元素,则返回-1表示目标元素不存在。

main方法中,我们定义了一个有序数组arr和一个目标元素target,然后调用binarySearch方法进行查找。如果返回的结果为-1,则输出"目标元素不存在";否则输出"目标元素的索引为:"加上返回的结果。

这个例子展示了如何使用Java实现二分查找算法,并且给出了一个具体的使用场景。你可以根据实际需求修改数组和目标元素来进行测试。

千锋教育拥有多年IT培训服务经验,开设Java培训web前端培训大数据培训python培训软件测试培训等课程,采用全程面授高品质、高体验教学模式,拥有国内一体化教学管理及学员服务,想获取更多IT技术干货请关注千锋教育IT培训机构官网。

#java二分查找算法的例子

相关文章

Spring(boot)中的context和environment的区别是什么?

Spring(boot)中的context和environment的区别是什么?

2023-10-16
java泛型,如何理解参数带Class和Class的区别?

java泛型,如何理解参数带Class和Class的区别?

2023-10-16
Integer.parseInt和Integer.valueOf有什么区别?

Integer.parseInt和Integer.valueOf有什么区别?

2023-10-16
Java 8用哪个版本Java EE? 不同版本Java EE有什么区别??

Java 8用哪个版本Java EE? 不同版本Java EE有什么区别??

2023-10-16

最新文章

常见网络安全面试题:Windows常用的命令有哪些?

常见网络安全面试题:Windows常用的命令有哪些?

2023-10-09
常见网络安全面试题:根据设备告警如何展开排查?

常见网络安全面试题:根据设备告警如何展开排查?

2023-10-09
常见网络安全面试题:mysql加固呢?(数据库加固)

常见网络安全面试题:mysql加固呢?(数据库加固)

2023-10-09
常见网络安全面试题:windows和linux加固?(操作系统加固)

常见网络安全面试题:windows和linux加固?(操作系统加固)

2023-10-09
在线咨询 免费试学 教程领取