博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
二分查找
阅读量:4072 次
发布时间:2019-05-25

本文共 995 字,大约阅读时间需要 3 分钟。

二分查找找出元素第一次出现的下标位置若未找到 输出-1-(应该出现的位置)
{1,3,5,8} 找7  则输出-4  找10  则输出-5  找0  则输出-1
package test;public class Test {	public static void main(String[] args) {		int[] nums={1,3,5,8};		int n= searchInsert(nums, 0); 		System.out.println(n);	}		   public static int searchInsert(int[] nums, int target) {  	        if (nums == null || nums.length == 0) {  	            return 0;  	        }  	        int start = 0, end = nums.length - 1;  	        while (start + 1 < end) {  	            int mid = start + (end - start) / 2;  	            if (nums[mid] == target) {  	                return mid;  	            } else if (nums[mid] < target) {  	                start = mid;  	            } else {  	                end = mid;  	            }  	        }  	        //第一个	        if (target <= nums[start]) {  	            return -(start+1);  	        }  	        //中间	        if (target <= nums[end]) {  	            return -(end + 1);  	        }  	        //最后一个 	        return -(end + 2);  	    }  }

转载地址:http://ukkni.baihongyu.com/

你可能感兴趣的文章
【数据结构周周练】008 二叉树的链式创建及测试
查看>>
《软件体系结构》 第九章 软件体系结构评估
查看>>
《软件体系结构》 第十章 软件产品线体系结构
查看>>
《软件过程管理》 第六章 软件过程的项目管理
查看>>
《软件过程管理》 第九章 软件过程的评估和改进
查看>>
分治法 动态规划法 贪心法 回溯法 小结
查看>>
《软件体系结构》 练习题
查看>>
《数据库系统概论》 第一章 绪论
查看>>
《数据库系统概论》 第二章 关系数据库
查看>>
《数据库系统概论》 第三章 关系数据库标准语言SQL
查看>>
SQL语句(二)查询语句
查看>>
SQL语句(六) 自主存取控制
查看>>
《计算机网络》第五章 运输层 ——TCP和UDP 可靠传输原理 TCP流量控制 拥塞控制 连接管理
查看>>
堆排序完整版,含注释
查看>>
二叉树深度优先遍历和广度优先遍历
查看>>
生产者消费者模型,循环队列实现
查看>>
PostgreSQL代码分析,查询优化部分,process_duplicate_ors
查看>>
PostgreSQL代码分析,查询优化部分,canonicalize_qual
查看>>
PostgreSQL代码分析,查询优化部分,pull_ands()和pull_ors()
查看>>
IA32时钟周期的一些内容
查看>>