和至少为k的最短子数组 python_和至少为k的最短子数组

// 单调栈

// 维护一个具有栈单调性的队列,跟动态规划不一样的是时间复杂度为O(n)

// queue[i]中存放着前缀和

// 我们知道因为负数的存在,所以队列不是单调增长的,但是不单调的其实对我们没有用

// 因为肯定可以找到比它短的(因此我们移除比)

// opt(y)表示比固定的y最大的满足条件的x,因此y - x的最大值就是我们要的值

// 这个递增的队列

// 我们首先建立一个单调增栈

// 出栈则代表碰到了合适的值。因此记录大小

// 其实我更感觉是具有单调性质的滑动窗口呢。。。。。

func shortestSubarray(A []int, K int) int {

prefixSum := make([]int, len(A)+1)

shLen := math.MaxInt32

for i, a := range A {

prefixSum[i+1] = prefixSum[i] + a

}

queue := make([]int, 1, len(prefixSum))

for i := 1; i < len(prefixSum); i++ {

for len(queue) > 0 && prefixSum[queue[len(queue)-1]] >= prefixSum[i] {

queue = queue[:len(queue)-1]

}

queue = append(queue, i)

diff := prefixSum[queue[len(queue)-1]] - K

for len(queue) > 1 && diff >= prefixSum[queue[0]] {

l := i - queue[0]

if l < shLen {

shLen = l

}

queue = queue[1:]

}

}

if shLen == math.MaxInt32 {

return -1

}

return shLen

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值