千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术干货  > java二分查找算法的例子

java二分查找算法的例子

来源:千锋教育
发布人:xqq
时间: 2023-08-01 10:42:21 1690857741

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; // 如果未找到目标元素,则返回-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作为参数,并返回目标元素在数组中的索引。如果目标元素不存在,则返回-1。

算法的核心部分是一个循环,通过不断调整查找范围的左右边界来逐渐缩小查找范围,直到找到目标元素或查找范围为空。

在每次循环中,我们计算中间元素的索引mid,然后与目标元素进行比较。如果中间元素等于目标元素,则返回中间元素的索引。如果中间元素小于目标元素,则将左边界调整为中间元素的右边一位。如果中间元素大于目标元素,则将右边界调整为中间元素的左边一位。

如果循环结束时仍未找到目标元素,则返回-1。

main方法中,我们定义了一个有序数组arr和目标元素target,然后调用binarySearch方法进行查找。根据返回的结果,我们输出相应的提示信息。

这个例子演示了如何使用Java实现二分查找算法,并展示了如何在一个有序数组中查找目标元素的索引。

希望这个例子能帮助你理解和应用二分查找算法。如果你有任何问题,请随时提问。

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

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT