二分查找算法(非递归)

1.二分查找只适合用于有序的数列中进行查找(比如数字和字母等),将数列排序后再进行查找

2.二分查找法的运行时间为对数时间O(2^n),即查找到所需的目标位置只需要log2^n布,假设从[0,99]的队列(100个数,即n=100)中寻找到目标数30,则需要步数为log2^100,及最多需要查找7次(2^6<100<2^7)

package com.zou.Algorithm.binarysearchnorecursion;

public class BinarySearchNoRecursion {
public static void main(String[] args) {
int[]arr={1,3,8,10,67,100};
int index=binarySearch(arr,-1);
System.out.println("index="+index);
}
//二分查找的非递归实现
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;
}
}

 

posted @   开源遗迹  阅读(69)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
点击右上角即可分享
微信分享提示