刷题笔记day02-数组快慢指针

你的名字

977. 有序数组的平方

思路就是:

// 思路就是,可能有负数的情况,那么平方后的数,一定是首尾之间选择。

那么使用双指针的方法就可以实现这个问题。

// 那么只需要比较一波,选择最大的既可

go 复制代码
func sortedSquares(nums []int) []int {
   
    
    var (
        length = len(nums)
        i = 0
        j = length - 1
        k = length - 1
        result = make([]int, length)
    )
    // 遍历
    for i <= j {
        if nums[i] * nums[i] < nums[j] * nums[j] {
            result[k] = nums[j] * nums[j]
            j--
        } else {
            result[k] = nums[i] * nums[i]
            i++
        }
        k--
    }
    return result
}

977. 有序数组的平方

当出现大于 target 的时候,那么就是将慢指针往前移动,如果还大,就在判断子序列的长度和result的大小。

python 复制代码
class Solution:
    # 用python实现一下
    # 主要还是使用滑动窗口的方法
    def minSubArrayLen(self, target: int, nums: List[int]) -> int:

        subLength: int = 0
        result: int = pow(10, 9)
        sum: int = 0
        i: int = 0

        # 迭代
        for j in range(len(nums)):
            sum += nums[j]
            # 滑动窗口的精髓,
            while (sum >= target):
                subLength = j - i + 1
                result = subLength if subLength < result else result
                # print(result)
                # 窗口:前置向后移动一位
                sum -= nums[i]
                i += 1

        return result if result != pow(10, 9) else 0
        ```
## 59. 螺旋矩阵 II
思路就是,上,右,下,左,范围:左闭右开的原则

````python
class Solution:
    
    def generateMatrix(self, n: int) -> List[List[int]]:
        pad: int = 1
        result: List[List[int]] = [[0]*n for i in range(n)]

        # 计数
        count: int  = 1
        rowLow: int = 0
        rowHigh: int = n-1
        colLow: int = 0
        colHigh: int = n-1 

        i: int = 0
        j: int = 0
        

        while True:
            # 上
            # for
            j = colLow
            for j in range(colLow, colHigh+1):
                result[rowLow][j] = count
                count += 1
            # print(result)
            # 上面往里缩进
            rowLow += 1
            if rowLow > rowHigh:
                break
            # 右
            for i in range(rowLow, rowHigh+1):
                result[i][colHigh] = count
                count += 1
            # 右边往里缩进
            colHigh -= 1
            if colHigh < colLow:
                break

            # +++++
            # 下
            # j = colHigh
            for j in range(colHigh, colLow-1, -1):
                result[rowHigh][j] = count
                count += 1
            # 下面往上缩进
            rowHigh -= 1
            if rowHigh < rowLow:
                break
            # 左
            # i = rowLow
            for i in range(rowHigh, rowLow-1, -1):
                result[i][colLow] = count
                count += 1
            # 左边往里缩进
            colLow += 1
            if colLow > colHigh:
                break
        return result
        ```
相关推荐
LuH11241 小时前
【论文阅读笔记】IC-Light
论文阅读·笔记
是小菜呀!1 小时前
实验四 触发器
笔记
悲伤小伞1 小时前
C++_数据结构_详解二叉搜索树
c语言·数据结构·c++·笔记·算法
灰太狼不爱写代码4 小时前
CUDA11.4版本的Pytorch下载
人工智能·pytorch·笔记·python·学习
Aileen_0v010 小时前
【AI驱动的数据结构:包装类的艺术与科学】
linux·数据结构·人工智能·笔记·网络协议·tcp/ip·whisper
Rinai_R12 小时前
计算机组成原理的学习笔记(7)-- 存储器·其二 容量扩展/多模块存储系统/外存/Cache/虚拟存储器
笔记·物联网·学习
吃着火锅x唱着歌12 小时前
PHP7内核剖析 学习笔记 第四章 内存管理(1)
android·笔记·学习
ragnwang12 小时前
C++ Eigen常见的高级用法 [学习笔记]
c++·笔记·学习
胡西风_foxww13 小时前
【es6复习笔记】rest参数(7)
前端·笔记·es6·参数·rest
胡西风_foxww16 小时前
【es6复习笔记】函数参数的默认值(6)
javascript·笔记·es6·参数·函数·默认值