代码随想录算法训练营第二天 | 双指针

简介: 代码随想录算法训练营第二天 | 双指针

一、前言

今天是参加 卡哥算法训练营的第二天, 任务如下所示

网络异常,图片无法展示
|

二、1640. 能否连接形成数组

题目描述

网络异常,图片无法展示
|

思路分析

这道题也做过好几遍了, 这次竟然一次通过

这题也是左右遍历双指针的思路, 需要注意的是数组元素可能为负数

代码展示

public int[] sortedSquares(int[] nums) {
    int left = 0, right = nums.length - 1, n = nums.length - 1;
    int[] result = new int[nums.length];
    while(left <= right){
        int leftNum = nums[left] * nums[left];
        int rightNum = nums[right] * nums[right];
        if (leftNum >= rightNum){
            left++;
            result[n] = leftNum;
        }else{
            right--;
            result[n] = rightNum;
        }
        n--;
    }
    return result;
}
复制代码

提交结果

网络异常,图片无法展示
|

补充

结果上来看内存使用过多, 发现自己在每次循环的时候都会去创建两个对象去存储 nums[left] 和 nums[right]的平方值, 那么我直接把它的创建提出去, 内存消耗唰的一下就降下来了

网络异常,图片无法展示
|

三、 209. 长度最小的子数组

题目描述

网络异常,图片无法展示
|

思路分析

依旧是双指针玩法

right一直前进, 如果 nums[left]到 nums[right]的和大于等于 target的话就移动 left前进,继续判断

注意可能数组 nums所有元素和加起来都小于 target, 所以先使 num = Integer.MAX_VALUE , 最后判断一下

代码展示

class Solution {
    public int minSubArrayLen(int target, int[] nums) {
        int result = Integer.MAX_VALUE;
        int left = 0, right = 0,num = 0;
        for (; right < nums.length; right++) {
            num += nums[right];
            while(num >= target){
                result = Math.min(result, right - left + 1);
                num -= nums[left];
                left++;
            }
        }
        return result == Integer.MAX_VALUE ? 0 : result;
    }
}
复制代码

提交结果

网络异常,图片无法展示
|

总结

又是一道几个月之前做过的题目,再一次做的时候细节还是没有把控好, 后面要注意

四、 59. 螺旋矩阵 II

题目描述

网络异常,图片无法展示
|

思路分析

这道题麻了,只记得大概,边界还总控制不好

首先可以确定我们的返回值, 因为是 int[n][n]的, 其次我们可以判断出来他是一圈一圈的进行赋值

然后要把控好这个边界的问题

模拟顺时针画矩阵的过程:

  • 填充上行从左到右
  • 填充右列从上到下
  • 填充下行从右到左
  • 填充左列从下到上

最后根据以上分析写出下面的代码

代码展示

class Solution {
    // 创建返回值
    int[][] res = new int[n][n];
    // 定义当前是第几圈
    int loopNum = 0;
    // 动态,指定下标使用
    int i = 0,j = 0;
    // 开始的元素下标定位和当前值
    int start = 0, count = 1;
    // 一共有 n/2 圈, 每次赋值一圈元素
    while(loopNum++ < n / 2){
        // 行赋值
        for (i = start; i < n - loopNum;i++){
            res[start][i] = count++;
        }
        // 列赋值
        for(j = start; j < n - loopNum; j++){
            res[j][i] = count++;
        }
        // 行~
        for (; i >= loopNum ; i--){
            res[j][i] = count++;
        }
        // 列~
        for(; j >= loopNum ; j--){
            res[j][start] = count++;
        }
        // 下标增加
        start++;
    }
    // 可能有最中间元素未赋值, 进行判断
    if (n % 2 == 1){
        res[start][start] = count;
    }
    return res;
}
复制代码

提交结果

网络异常,图片无法展示
|

总结

这个是真的麻爪了, 在模拟顺时针化矩阵的时候总是出错,最后还是看了题解才把控好这个边界的问题

五、每日一题 1640. 能否连接形成数组

题目描述

网络异常,图片无法展示
|

思路分析

里面需要注意的就是不允许 对每个数组 pieces[i] 中的整数重新排序。这个最开始忘记了, 走了很多弯路

代码分析:

  • 先去获取 pieces里面每个数组的首位元素, 因为题中有说值不重复, 那么直接放入 map中就可以了
  • 然后就是去遍历判断是否相等, 这里需要注意的是 i++ 这个条件不要放在最外层循环, 容易跳过, 也吃了个亏

代码展示

class Solution {
    public boolean canFormArray(int[] arr, int[][] pieces) {
        Map<Integer, int[]> map = new HashMap<>();
        for (int[] piece : pieces) {
            map.put(piece[0], piece);
        }
        for (int i = 0; i < arr.length;) {
            if (!map.containsKey(arr[i])){
                return false;
            }
            int[] ints = map.get(arr[i]);
            for (int j = 0; j < ints.length; j++,i++) {
                if (ints[j] != arr[i]){
                    return false;
                }
            }
        }
        return true;
    }
}
复制代码

提交结果

网络异常,图片无法展示
|

总结

老问题, 能放到外面定义的对象就尽量放到循环外面, 要不然就是纯纯增加内存消耗

网络异常,图片无法展示
|



宁轩
+关注
目录
打赏
0
0
0
0
2
分享
相关文章
JavaScript 中通过Array.sort() 实现多字段排序、排序稳定性、随机排序洗牌算法、优化排序性能,JS中排序算法的使用详解(附实际应用代码)
Array.sort() 是一个功能强大的方法,通过自定义的比较函数,可以处理各种复杂的排序逻辑。无论是简单的数字排序,还是多字段、嵌套对象、分组排序等高级应用,Array.sort() 都能胜任。同时,通过性能优化技巧(如映射排序)和结合其他数组方法(如 reduce),Array.sort() 可以用来实现高效的数据处理逻辑。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
近端策略优化(PPO)算法的理论基础与PyTorch代码详解
近端策略优化(PPO)是深度强化学习中高效的策略优化方法,广泛应用于大语言模型的RLHF训练。PPO通过引入策略更新约束机制,平衡了更新幅度,提升了训练稳定性。其核心思想是在优势演员-评论家方法的基础上,采用裁剪和非裁剪项组成的替代目标函数,限制策略比率在[1-ϵ, 1+ϵ]区间内,防止过大的策略更新。本文详细探讨了PPO的基本原理、损失函数设计及PyTorch实现流程,提供了完整的代码示例。
424 10
近端策略优化(PPO)算法的理论基础与PyTorch代码详解
【算法】——双指针算法合集(力扣)
移动零,复写零,快乐数,盛最多水的容器,有效三角形的个数,和为s的两个数(查找总价格为目标值的两个商品 ),三数之和,四数之和
C 语言递归算法:以简洁代码驾驭复杂逻辑
C语言递归算法简介:通过简洁的代码实现复杂的逻辑处理,递归函数自我调用解决分层问题,高效而优雅。适用于树形结构遍历、数学计算等领域。
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
115 1
通过优化算法和代码结构来提升易语言程序的执行效率
通过优化算法和代码结构来提升易语言程序的执行效率
122 2
分享一些提高二叉树遍历算法效率的代码示例
这只是简单的示例代码,实际应用中可能还需要根据具体需求进行更多的优化和处理。你可以根据自己的需求对代码进行修改和扩展。
基于生物地理算法的MLP多层感知机优化matlab仿真
本程序基于生物地理算法(BBO)优化MLP多层感知机,通过MATLAB2022A实现随机数据点的趋势预测,并输出优化收敛曲线。BBO模拟物种在地理空间上的迁移、竞争与适应过程,以优化MLP的权重和偏置参数,提升预测性能。完整程序无水印,适用于机器学习和数据预测任务。
106 31
基于LSB最低有效位的音频水印嵌入提取算法FPGA实现,包含testbench和MATLAB对比
本项目展示了一种基于FPGA的音频水印算法,采用LSB(最低有效位)技术实现版权保护与数据追踪功能。使用Vivado2019.2和Matlab2022a开发,完整代码含中文注释及操作视频。算法通过修改音频采样点的最低有效位嵌入水印,人耳难以察觉变化。然而,面对滤波或压缩等攻击时,水印提取可能受影响。该项目运行效果无水印干扰,适合实时应用场景,核心逻辑简单高效,时间复杂度低。
基于GA遗传算法的拱桥静载试验车辆最优布载matlab仿真
本程序基于遗传算法(GA)实现拱桥静载试验车辆最优布载的MATLAB仿真,旨在自动化确定车辆位置以满足加载效率要求(0.95≤ηq≤1.05),目标是使ηq尽量接近1,同时减少车辆数量和布载耗时。程序在MATLAB 2022A版本下运行,展示了工况1至工况3的测试结果。通过优化模型,综合考虑车辆重量、位置、类型及车道占用等因素,确保桥梁关键部位承受最大荷载,从而有效评估桥梁性能。核心代码实现了迭代优化过程,并输出最优布载方案及相关参数。

热门文章

最新文章