Python 官方文档:入门教程 => 点击学习
文章目录 81. 搜索旋转排序数组 II:样例 1:样例 2:提示:进阶: 分析:题解:rust:go:c++:python:java: 81. 搜索旋转排序数组 II: 已知
已知存在一个按非降序排列的整数数组 nums
,数组中的值不必互不相同。
在传递给函数之前,nums
在预先未知的某个下标 k
(0 <= k < nums.length
)上进行了 旋转 ,使数组变为 [nums[k], nums[k+1], ..., nums[n-1], nums[0], nums[1], ..., nums[k-1]]
(下标 从 0 开始 计数)。例如, [0,1,2,4,4,4,5,6,6,7]
在下标 5
处经旋转后可能变为 [4,5,6,6,7,0,1,2,4,4]
。
给你 旋转后 的数组 nums
和一个整数 target
,请你编写一个函数来判断给定的目标值是否存在于数组中。如果 nums
中存在这个目标值 target
,则返回 true
,否则返回 false
。
你必须尽可能减少整个操作步骤。
输入:nums = [2,5,6,0,0,1,2], target = 0输出:true
输入:nums = [2,5,6,0,0,1,2], target = 3输出:false
nums
可能包含重复元素。impl Solution { pub fn search(nums: Vec<i32>, target: i32) -> bool { let n = nums.len(); if n == 0 { return false; } if n == 1 { return nums[0] == target; } let (mut l, mut r) = (0, n - 1); while l <= r { let mid = (l + r) >> 1; if nums[mid] == target { return true; } if nums[l] == nums[mid] && nums[mid] == nums[r] { if r == 0 { // 防止r溢出到非常大 return false; } l += 1; r -= 1; } else if nums[l] <= nums[mid] { if nums[l] <= target && target < nums[mid] { r = mid - 1; } else { l = mid + 1; } } else { if nums[mid] < target && target <= nums[n - 1] { l = mid + 1; } else { r = mid - 1; } } } return false; }}
func search(nums []int, target int) bool { n := len(nums)if n == 0 {return false}if n == 1 {return nums[0] == target}l, r := 0, n-1for l <= r {mid := (l + r) >> 1if nums[mid] == target {return true}if nums[l] == nums[mid] && nums[mid] == nums[r] {l++r--} else if nums[l] <= nums[mid] {if nums[l] <= target && target < nums[mid] {r = mid - 1} else {l = mid + 1}} else {if nums[mid] < target && target <= nums[n-1] {l = mid + 1} else {r = mid - 1}}}return false}
class Solution {public: bool search(vector<int>& nums, int target) { const int n = nums.size(); if (n == 0) { return false; } if (n == 1) { return nums[0] == target; } int l = 0, r = n - 1; while (l <= r) { int mid = (l + r) >> 1; if (nums[mid] == target) { return true; } if (nums[l] == nums[mid] && nums[mid] == nums[r]) { ++l; --r; } else if (nums[l] <= nums[mid]) { if (nums[l] <= target && target < nums[mid]) { r = mid - 1; } else { l = mid + 1; } } else { if (nums[mid] < target && target <= nums[n - 1]) { l = mid + 1; } else { r = mid - 1; } } } return false; }};
class Solution: def search(self, nums: List[int], target: int) -> bool: if not nums: return False n = len(nums) if n == 1: return nums[0] == target l, r = 0, n - 1 while l <= r: mid = (l + r) >> 1 if nums[mid] == target: return True if nums[l] == nums[mid] and nums[mid] == nums[r]: l += 1 r -= 1 elif nums[l] <= nums[mid]: if nums[l] <= target < nums[mid]: r = mid - 1 else: l = mid + 1 else: if nums[mid] < target <= nums[n - 1]: l = mid + 1 else: r = mid - 1 return False
class Solution { public boolean search(int[] nums, int target) { final int n = nums.length; if (n == 0) { return false; } if (n == 1) { return nums[0] == target; } int l = 0, r = n - 1; while (l <= r) { int mid = (l + r) / 2; if (nums[mid] == target) { return true; } if (nums[l] == nums[mid] && nums[mid] == nums[r]) { ++l; --r; } else if (nums[l] <= nums[mid]) { if (nums[l] <= target && target < nums[mid]) { r = mid - 1; } else { l = mid + 1; } } else { if (nums[mid] < target && target <= nums[n - 1]) { l = mid + 1; } else { r = mid - 1; } } } return false; }}
非常感谢你阅读本文~
欢迎【点赞】【收藏】【评论】三连走一波~
放弃不难,但坚持一定很酷~
希望我们大家都能每天进步一点点~
本文由 二当家的白帽子:https://le-yi.blog.csdn.net/ 博客原创~
来源地址:https://blog.csdn.net/leyi520/article/details/132888132
--结束END--
本文标题: 算法leetcode|81. 搜索旋转排序数组 II(rust重拳出击)
本文链接: https://lsjlt.com/news/413786.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0