leetcode 搜索旋转排序数组 golang


本文摘自网络,作者,侵删。

81. 搜索旋转排序数组 II

解题思路

二分的变形,我们之前二分查找基于这样的一个假设:我们定位到一个元素后,这个元素的前后分别都是单调的。
但是这边的数组是旋转的。
所以我们需要修改的是判定逻辑

  1. 如果我们可以判定出来 那边是旋转的,那边是自增的。则可以通过边界判断
  2. 如果不行,则进行递归。

代码实现

func search(nums []int, target int) bool {
    i,j := 0,len(nums)-1
    A := nums
    for i<=j{
        mid := (i+j)/2
        if A[mid]==target{
            return true
        }
        if (A[mid]==A[j]||A[mid]==A[i]) && (search(nums[mid+1:j+1],target) || search(nums[i:mid],target)){
            return true
        }
      
        if A[mid] < A[j]{
            if target > A[mid] && target <= A[j]{
                i = mid+1
            }else{
                j = mid-1
            }
        }else{
            if target >= A[i] && target < A[mid]{
                j = mid-1
            }else{
                i = mid+1
            }
        }
    }
    return false
}

本文来自:简书

感谢作者:lucasgao

查看原文:leetcode 搜索旋转排序数组 golang

相关阅读 >>

[Golang]从sync.waitgroup看内存对齐

这可能是最容易理解的 Go mutex 源码剖析

Go语言开发工具

[系列] - Go-gin-api 规划目录和参数验证(二)

安装Go语言支持及Gogs版本管理工具

Gocn酷Go推荐】Go程序配置利器-viper库

Golang websocket失败怎么办

python中的数据类型

Golang cap是什么意思

手撸Golang 创建型设计模式 工厂方法

更多相关阅读请进入《Go》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...