二分查找算法(非递归)
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;
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报