程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> (每日算法)LeetCode --- Search in Rotated Sorted Array(旋轉數組的二分檢索)

(每日算法)LeetCode --- Search in Rotated Sorted Array(旋轉數組的二分檢索)

編輯:C++入門知識

(每日算法)LeetCode --- Search in Rotated Sorted Array(旋轉數組的二分檢索)


Search in Rotated Sorted Array I && II

Leetcode


對有序數組進行二分查找(下面僅以非遞減數組為例):

  1. int binarySort(int A[], int lo, int hi, int target)
  2. {
  3. while(lo <= hi)
  4. {
  5. int mid = lo + (hi - lo)/2;
  6. if(A[mid] == target)
  7. return mid;
  8. if(A[mid] < target)
  9. lo = mid + 1;
  10. else
  11. hi = mid - 1;
  12. }
  13. }

對有序的旋轉數組進行二分查找:

eg. [7, 8, 9, 3, 4, 5, 6]

在數組中有且僅有一個 斷點 (數字由大變小)。

還是通過折半來實現,關鍵是如有巧妙的繞過這個斷點。

1.如果前半部分有序:

target 在該區間內,則 hi = mid - 1

不在該區間內,則 lo = mid + 1

2.如果前半部分無序

target 在後半部分的有序區間內,則 lo = mid + 1

不在該區間內, 則 hi = mid - 1

也就是說,我們優先考慮有序的部分。

  1. int search(int A[], int lo, int hi, int target)
  2. {
  3. while (lo <= hi)
  4. {
  5. int mid = (lo + hi) / 2;
  6. if (A[mid] == target)
  7. return mid;
  8. if (A[lo] <= A[mid])
  9. {
  10. if (A[lo] <= target && target < A[mid])
  11. hi = mid - 1;
  12. else
  13. lo = mid + 1;
  14. } else {
  15. if (A[mid] < target && target <= A[hi-1])
  16. lo = mid + 1;
  17. else
  18. hi = mid - 1;
  19. }
  20. }
  21. return -1;
  22. }

對包含重復元素的旋轉數組進行二分查找:

允許重復元素,則上一題中如果A[m]>=A[l],那麼[l,m]為遞增序列的假設就不能成立了,比如[1,3,1,1,1]。

如果A[m]>=A[l]不能確定遞增,那就把它拆分成兩個條件:

若A[m]>A[l],則區間[l,m]一定遞增

若A[m]==A[l]確定不了,那就l++,往下看一步即可。

  1. bool search(int A[], int lo, int hi, int target)
  2. {
  3. while (lo <= hi)
  4. {
  5. int mid = (lo + hi) / 2;
  6. if (A[mid] == target)
  7. return true;
  8. if (A[lo] < A[mid])
  9. {
  10. if (A[lo] <= target && target < A[mid])
  11. hi = mid - 1;
  12. else
  13. lo = mid + 1;
  14. } else if(A[lo] > A[mid]) {
  15. if (A[mid] < target && target <= A[hi-1])
  16. lo = mid + 1;
  17. else
  18. hi = mid - 1;
  19. }
  20. else
  21. lo++;
  22. }
  23. return false;
  24. }

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved