力扣题目地址:https://leetcode-cn.com/problems/search-insert-position/
首先看题目:
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
你可以假设数组中无重复元素。
示例:
示例 1:
输入: [1,3,5,6], 5
输出: 2
示例 2:
输入: [1,3,5,6], 2
输出: 1
示例 3:
输入: [1,3,5,6], 7
输出: 4
示例 4:
输入: [1,3,5,6], 0
输出: 0
解决思路:
今天加班很晚了,这单题目相对简单。首先我们派出两种特殊情况:目标值小于数组第一个元素的情况;目标值大于数组最后一个元素的情况。然后我们还有两种情况:目标值等于数组元素值;目标值在数组中不存在,我们需要获取插入的位置。我们可以通过遍历数组找出这两种情况对应的索引值。
代码实现:
/**
* 搜索插入位置
* https://leetcode-cn.com/problems/search-insert-position/
*
* @param nums
* @param target
* @author Geyuxuan 2020-03-12 23:56:17
* @return int
*/
public int searchInsert(int[] nums, int target) {
//排除目标值小于数组第一个元素的情况
if(target<nums[0]){
return 0;
}
//排除目标值大于数组最后一个元素的情况
if(target>nums[nums.length-1]){
return nums.length;
}
//遍历出目标值所在位置
for(int i = 0; i < nums.length; i++) {
//如果数组中存在目标值,找出相等的位置
if(target == nums[i]){
return i;
}
//如果没有相等值,找出可插入的位置
//可插入位置为大于前一个元素,小于后一个元素
if(nums[i] < target && target < nums[i+1]){
return i+1;
}
}
return -1;
}
不忘初心,砥砺前行。