博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在给定的一维已排序(升序)数组中寻找插入一个元素的位置
阅读量:4040 次
发布时间:2019-05-24

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

在给定的一维已排序(升序)数组中寻找插入一个元素的位置

在给定的一维已排序(升序)数组中寻找插入一个元素的位置,返回该元素在数组中的下标值。

如果该元素已经存在于数组中,则直接返回该元素在数组中的下标值。

例如:给定数组 {1,3,4,5,6,9,11},目标值是 7。

数组中不包含目标值,插入目标之后,数组变为: {1,3,4,5,6,7,9,11},返回下标值:5。

再例如:给定数组 {1,3,4,5,6,9,11},目标值是 5。

数组中包含目标值,返回下标值:3。

算法设计

public static int searchInsert(int[] nums, int target) {        int low = 0, high = nums.length;        while(low < high) {            int mid = low + (high - low) / 2;            if(nums[mid] < target)                low = mid + 1;            else                high = mid;        }        return low;    }

完整测试代码如下:

采用二分查找思路。

package com.bean.algorithmbasic;public class SearchInsertPosition {    public static int searchInsert(int[] nums, int target) {        int low = 0, high = nums.length;        while(low < high) {            int mid = low + (high - low) / 2;            if(nums[mid] < target)                low = mid + 1;            else                high = mid;        }        return low;    }    public static void main(String[] args) {        // TODO Auto-generated method stub        int[] array= {
1,3,4,7,15,19,22,25}; //int target=10; int target=3; int ANSWER=searchInsert(array,target); System.out.println("ANSWER = "+ANSWER); }}

运行结果

ANSWER = 1

(完)

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

你可能感兴趣的文章
01Java基础语法-18. 各种循环语句的区别和应用场景
查看>>
01Java基础语法-19. 循环跳转控制语句
查看>>
Django框架全面讲解 -- Form
查看>>
socket,accept函数解析
查看>>
今日互联网关注(写在清明节后):每天都有值得关注的大变化
查看>>
”舍得“大法:把自己的优点当缺点倒出去
查看>>
[今日关注]鼓吹“互联网泡沫,到底为了什么”
查看>>
[互联网学习]如何提高网站的GooglePR值
查看>>
[关注大学生]求职不可不知——怎样的大学生不受欢迎
查看>>
[关注大学生]读“贫困大学生的自白”
查看>>
[互联网关注]李开复教大学生回答如何学好编程
查看>>
[关注大学生]李开复给中国计算机系大学生的7点建议
查看>>
[关注大学生]大学毕业生择业:是当"鸡头"还是"凤尾"?
查看>>
[茶余饭后]10大毕业生必听得歌曲
查看>>
gdb调试命令的三种调试方式和简单命令介绍
查看>>
C++程序员的几种境界
查看>>
VC++ MFC SQL ADO数据库访问技术使用的基本步骤及方法
查看>>
VUE-Vue.js之$refs,父组件访问、修改子组件中 的数据
查看>>
Vue-子组件改变父级组件的信息
查看>>
Python自动化之pytest常用插件
查看>>