<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
思路:
程式碼
class Solution { public int search(int[] arr, int t) { if (arr == null || arr.length < 1) { return -1; } int l = 0; int r = arr.length - 1; while (l <= r) { int m = l + ((r - l) >> 1); if (arr[m] == t) { return m; } else if (arr[m] > t) { r = m - 1; } else { l = m + 1; } } return -1; } }
時間複雜度 O(logN)
。
範例 1:
輸入: nums = [1,3,5,6], target = 5
輸出: 2
說明:如果要在num
這個陣列中插入 5 這個元素,應該是插入在元素 3 和 元素 5 之間的位置,即 2 號位置。
範例 2:
輸入: nums = [1,3,5,6], target = 2
輸出: 1
說明:如果要在num
這個陣列中插入 2 這個元素,應該是插入在元素 1 和 元素 3 之間的位置,即 1 號位置。
範例 3:
輸入: nums = [1,3,5,6], target = 7
輸出: 4
說明:如果要在num
這個陣列中插入 7 這個元素,應該是插入在陣列末尾,即 4 號位置。
通過上述範例可以知道,這題本質上就是求在一個有序陣列中,找大於等於某個數最左側的位置,如果不存在,就返回陣列長度(表示插入在最末尾位置)
我們只需要在上例基礎上進行簡單改動即可,上例中,我們找到滿足條件的位置就直接return
了
if (arr[m] == t) { return m; }
在本問題中,因為要找到最左側的位置,所以,在遇到相等的時候,只需要先把位置記錄下來,不用直接返回,然後繼續去左側找是否還有滿足條件的更左邊的位置。
同時,在遇到arr[m] > t
條件下,也需要記錄下此時的m
位置,因為這也可能是滿足條件的位置。
程式碼:
class Solution { public static int searchInsert(int[] arr, int t) { int ans = arr.length; int l = 0; int r = arr.length - 1; while (l <= r) { int m = l + ((r - l)>>1); if (arr[m] >= t) { ans = m; r = m - 1; } else { l = m + 1; } } return ans; } }
整個演演算法的時間複雜度是O(logN)
。
思路
本題也是用二分來解,當通過二分找到某個元素的時候,不急著返回,而是繼續往左(右)找,看能否找到更左(右)位置匹配的值。
程式碼如下:
class Solution { public static int[] searchRange(int[] arr, int t) { if (arr == null || arr.length < 1) { return new int[]{-1, -1}; } return new int[]{left(arr,t),right(arr,t)}; } public static int left(int[] arr, int t) { if (arr == null || arr.length < 1) { return -1; } int ans = -1; int l = 0; int r = arr.length - 1; while (l <= r) { int m = l + ((r - l) >> 1); if (arr[m] == t) { ans = m; r = m - 1; } else if (arr[m] < t) { l = m +1; } else { // arr[m] > t r = m - 1; } } return ans; } public static int right(int[] arr, int t) { if (arr == null || arr.length < 1) { return -1; } int ans = -1; int l = 0; int r = arr.length - 1; while (l <= r) { int m = l + ((r - l) >> 1); if (arr[m] == t) { ans = m; l = m + 1; } else if (arr[m] < t) { l = m +1; } else { // arr[m] > t r = m - 1; } } return ans; } }
時間複雜度 O(logN)
。
思路
假設陣列長度為N
,首先判斷0
號位置的數和N-1
位置的數是不是峰值位置。
0
號位置只需要和1
號位置比較,如果0
號位置大,0
號位置就是峰值位置,可以直接返回。
N-1
號位置只需要和N-2
號位置比較,如果N-1
號位置大,N-1
號位置就是峰值位置,可以直接返回。
如果0
號位置和N-1
在上輪比較中均是最小值,那麼陣列的樣子必然是如下情況:
由上圖可知,[0..1]
區間內是增長趨勢, [N-2...N-1]
區間內是下降趨勢。
那麼峰值位置必在[1...N-2]
之間出現。
此時可以通過二分來找峰值位置,先來到中點位置,假設為mid
,如果中點位置的值比左右兩邊的值都大:
arr[mid] > arr[mid+1] && arr[mid] > arr[mid-1]
則mid
位置即峰值位置,直接返回。
否則,有如下兩種情況:
情況一:mid 位置的值比 mid - 1 位置的值小
趨勢如下圖:
則在[1...(mid-1)]
區間內繼續二分。
情況二:mid 位置的值比 mid + 1 位置的值小
趨勢是:
則在[(mid+1)...(N-2)]
區間內繼續上述二分。
完整程式碼
public class LeetCode_0162_FindPeakElement { public static int findPeakElement(int[] nums) { if (nums.length == 1) { return 0; } int l = 0; int r = nums.length - 1; if (nums[l] > nums[l + 1]) { return l; } if (nums[r] > nums[r - 1]) { return r; } l = l + 1; r = r - 1; while (l <= r) { int mid = l + ((r - l) >> 1); if (nums[mid] > nums[mid + 1] && nums[mid] > nums[mid - 1]) { return mid; } if (nums[mid] < nums[mid + 1]) { l = mid + 1; } else if (nums[mid] < nums[mid - 1]) { r = mid - 1; } } return -1; } }
時間複雜度O(logN)
。
到此這篇關於詳解Java中二分法的基本思路和實現的文章就介紹到這了,更多相關Java二分法內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45