长度最小的子数组 leetcode209
初次尝试之动态规划 × 超出内存限制
利用如下图所示的思想,但是使用的空间太大了
go
// 动态规划方法 超出内存限制
func minSubArrayLen(target int, nums []int) int {
L := len(nums)
table := make([][]int, L)
length := 0
for i := 0; i < L; i++ {
if nums[i] >= target {
length = 1
return length
}
table[i] = make([]int, L) //结果表
table[i][i] = nums[i] //对角线就是原本数据
//fmt.Println(table[i])
}
//x, y := 0, 1
//char := 0
outLoop:
for i := 0; i < L-1; i++ {
x := 0 //行数都是从0开始
for y := i + 1; y < L; y++ {
table[x][y] = table[x][y-1] + table[x+1][y] - table[x+1][y-1]
if table[x][y] >= target { //如果当前的连续已经超过或等于target
length = y - x + 1
break outLoop //第一个大于target的目标即为最短的连续数组
}
x++
}
}
for i := 0; i < L; i++ {
fmt.Println(table[i])
}
return length
}
滑动窗口(?)我的猪鼻版本
go
func minSubArrayLen(target int, nums []int) int {
L := len(nums)
n := 0 //n用来计算最小的连续数
left := 0
right := 0
add := 0
for { //第一个for用来找到第一组满足要求的连续数,后续再进行缩小
right = left + n
if right == L {
return 0
}
add += nums[right]
n++
if add >= target {
N := n - 1
for left != L { //第二个for进行缩小
add -= nums[left]
left++
if add >= target {
n--
N = n - 1
continue
}
right = left + N
if right == L {
break
}
add += nums[right]
}
return n
}
}
}
正宗版滑动窗口
go
func minSubArrayLen(target int, nums []int) int {
add := 0
left, right := 0, 0
L := len(nums)
length := L + 1 //为了方便判断有无总和超过target
for right != L {
add += nums[right]
for add >= target { //当 当前 窗口内总和大于等于 target 为边界条件;
length = min(length, right-left+1) //更新最短长度
add -= nums[left] //删除画出的数据
left++ //左指针右移
}
right++
}
if length == L+1 {
return 0
}
return length
}