0%

LeetCode-35

LeetCode -35 搜索插入位置

题目

结果

代码

线性搜索

1
2
3
4
5
6
7
8
9
10
class Solution {
public static int searchInsert(int[] nums, int target) {
for (int i = 0; i < nums.length; i++) {
if (nums[i] >= target) {
return i;
}
}
return nums.length;
}
}

二分法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
class Solution {
public int searchInsert(int[] nums, int target) {
return searchInsert(nums, target, 0, nums.length - 1);
}

public int searchInsert(int[] nums, int target, int begin, int end) {
// 插入元素比所有元素都小或都大
if (nums[0] > target) {
return 0;
} else if (nums[nums.length - 1] < target) {
return nums.length - 1;
}


int middle = (begin + end) / 2;
if (middle == begin || middle == end) {
if (nums[begin] == target) {
return begin;
} else {
return end;
}
}

// 二分法
if (nums[middle] == target) {
return middle;
} else if (target < nums[middle]) {
return searchInsert(nums, target, begin, middle);
} else {
return searchInsert(nums, target, middle, end);
}
}
}

时间复杂度

线性搜索

  • 时间复杂度:O(n)

  • 空间复杂度:O(1)

二分法

  • 时间复杂度:O(logn)

  • 空间复杂度:O(1)