Leetcode挑戰: Day13 search insert position

leetcode

為了加強自己的程式能力,因此開始記錄每天刷leetcode的解法+說明,會用RubypythonJavaScript三個語言來解題,今天是第十三天,讓我們開始吧!

題目來源:leetcode

一開始看到題目原本想說,把數字插入陣列中排序後再返還索引值就好,但實際執行卻發現效率很差ʘ‿ʘ。

後來想到可以使用二分法,先取中間的數字與target比較,分成兩邊,這樣最多就只要比較陣列一半的數量就好,會比較有效率,就像是猜數字,如果一開始就對半猜,猜到數字的機率也會快很多。

Ruby

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
def search_insert(nums, target)
left, right = 0, nums.length - 1

while left <= right
mid = (left + right) / 2
if nums[mid] == target
return mid
elsif nums[mid] < target
left = mid + 1
else
right = mid - 1
end
end

return left
end

這裡的left是指陣列的起始索引值,為0right是陣列的結束值,為nums.length - 1mid就是中間的索引值(left+right)/2

如果照排序看可以這樣理解:
left,mid,right

一開始先猜中間,如果運氣好就是中間值,可直接返還mid

如果target比較大,即縮小left的範圍為mid + 1,比較數字的範圍也到了右半邊,接著會繼續新的迴圈,再繼續對半切取新的mid值比較。

如果target比較小,則縮小right的範圍為mid - 1,比較數字在左半邊,繼續新的迴圈,再繼續對半切取新的mid值比較。

直到nums[mid] = target,即會返還mid,也就是索引值。

Python

1
2
3
4
5
6
7
8
9
10
11
12
13
14
class Solution:
def searchInsert(self, nums, target):
left, right = 0, len(nums) - 1

while left <= right:
mid = (left + right) // 2
if nums[mid] == target:
return mid
elif nums[mid] < target:
left = mid + 1
else:
right = mid - 1

return left

python也是一樣邏輯,只是部分寫法不同

JavaScript

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
var searchInsert = function(nums, target) {
let left = 0, right = nums.length - 1;

while (left <= right) {
let mid = Math.floor((left + right) / 2);
if (nums[mid] == target) {
return mid;
} else if (nums[mid] < target) {
left = mid + 1;
} else {
right = mid - 1;
}
}

return left;
};

js也是相同,不過需要添加Math.floormid值為無條件捨去

這就是今天的解題了~其實不管什麼題目都可以用最笨的方法解,但是如果在讀題目時多想一點,就能讓程式碼效率更高!接下來幾天繼續加油🙌

Comments