1、题目要求
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
你可以假设数组中无重复元素。
示例 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
2、解体思路
暴力破解-循环遍历,判断数据的大小,用时
//暴力破解法
static int searchInsert(int[] nums, int target){
for (int i=0;i<nums.length;i++){
int vi = nums[i];
if (i<nums.length-1){
int n = i+1;
int vi1 = nums[n];
if (vi > target){
System.out.println(0);
return 0;
}
if (vi == target){
System.out.println(i);
return i;
}
if (vi<target && target<vi1){
System.out.println(n);
return n;
}
}else {
if (vi<target)
{
System.out.println(nums.length);
return nums.length;
}else {
System.out.println(nums.length-1);
return nums.length-1;
}
}
}
return 0;
}
二分解题,此方法是看官方的解法,自己实现
//二分查找
static int searchInsert2(int[] nums, int target){
int left = 0, right = nums.length - 1;
int rs = 0;
while(left <= right) {
int mid = (left + right) / 2;
if(nums[mid] == target) {
// 相关逻辑
return mid;
} else if(nums[mid] < target) {
left = mid + 1;
rs = left;
} else {
right = mid - 1;
if (right < 0){
return 0;
}
rs = mid;
}
}
// 相关返回值
return rs;
}
疫情无情人有情,解析刷题;