python旋转排序数组_LeetCode(力扣)——Search in Rotated Sorted Array 搜索旋转排序数组 python实现...
題目描述:
python實現Search in Rotated Sorted Array 搜索旋轉排序數組
中文:假設按照升序排序的數組在預先未知的某個點上進行了旋轉。
( 例如,數組?[0,1,2,4,5,6,7]?可能變為?[4,5,6,7,0,1,2]?)。
搜索一個給定的目標值,如果數組中存在這個目標值,則返回它的索引,否則返回?-1?。
你可以假設數組中不存在重復的元素。
你的算法時間復雜度必須是?O(log?n) 級別。
英文:Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand.
(i.e., [0,1,2,4,5,6,7] might become [4,5,6,7,0,1,2]).
You are given a target value to search. If found in the array return its index, otherwise return -1.
You may assume no duplicate exists in the array.
Your algorithm's runtime complexity must be in the order of?O(log?n).
1 classSolution(object):2 defsearch(self, nums, target):3 """
4 :type nums: List[int]5 :type target: int6 :rtype: int7 """
8 start =09 end = len(nums)-1
10 while start<=end:11 mid = (start + end)/2 #對于整數會自動省去小數部分
12 if nums[mid] ==target:13 returnmid14 if nums[mid]>=nums[start]:15 if target >= nums[start] and target<=nums[mid]:16 end = mid-1
17 else:18 start = mid + 1
19
20 if nums[mid] nums[mid] and target<=nums[end]:22 start = mid+1
23
24 else:25 end = mid -1
26 return -1
題目來源:力扣題庫
總結
以上是生活随笔為你收集整理的python旋转排序数组_LeetCode(力扣)——Search in Rotated Sorted Array 搜索旋转排序数组 python实现...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python 知乎 合并 pdf_一键下
- 下一篇: java c语言 for_Java能写C