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

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

一、前言

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

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

二、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;
    }
}
复制代码

提交结果

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

总结

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

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



目录
相关文章
|
2月前
|
机器学习/深度学习 人工智能 自然语言处理
【自然语言处理】TF-IDF算法在人工智能方面的应用,附带代码
TF-IDF算法在人工智能领域,特别是自然语言处理(NLP)和信息检索中,被广泛用于特征提取和文本表示。以下是一个使用Python的scikit-learn库实现TF-IDF算法的简单示例,并展示如何将其应用于文本数据。
215 65
|
1月前
|
算法 索引 容器
双指针算法详解
本文介绍了双指针算法及其应用。双指针算法是在数组或字符串中常用的高效技术,通过维护两个指针遍历数据结构以解决特定问题。根据指针移动方向,可分为同向双指针、相向双指针和快慢指针。同向双指针如移动零和复写零问题;快慢指针如快乐数问题;相向双指针如盛水最多的容器、有效三角形数量及多数之和等问题。通过合理运用双指针技巧,可简化代码并提高效率。
34 4
双指针算法详解
|
27天前
|
机器学习/深度学习 存储 算法
经典算法代码
这段代码展示了多个经典算法,包括:穷举法解决“百钱买百鸡”问题;递推法计算“猴子吃桃”问题;迭代法求解斐波那契数列及折纸高度超越珠峰的问题。同时,还提供了希尔排序算法实现及披萨票务订购系统和汉诺塔问题的链表存储解决方案。每部分通过具体案例解释了算法的应用场景与实现方法。
23 3
|
2月前
|
机器学习/深度学习 人工智能 算法
【人工智能】传统语音识别算法概述,应用场景,项目实践及案例分析,附带代码示例
传统语音识别算法是将语音信号转化为文本形式的技术,它主要基于模式识别理论和数学统计学方法。以下是传统语音识别算法的基本概述
56 2
|
2月前
|
人工智能 算法 数据可视化
DBSCAN密度聚类算法(理论+图解+python代码)
DBSCAN密度聚类算法(理论+图解+python代码)
|
2月前
|
数据采集 搜索推荐 算法
【高手进阶】Java排序算法:从零到精通——揭秘冒泡、快速、归并排序的原理与实战应用,让你的代码效率飙升!
【8月更文挑战第21天】Java排序算法是编程基础的重要部分,在算法设计与分析及实际开发中不可或缺。本文介绍内部排序算法,包括简单的冒泡排序及其逐步优化至高效的快速排序和稳定的归并排序,并提供了每种算法的Java实现示例。此外,还探讨了排序算法在电子商务、搜索引擎和数据分析等领域的广泛应用,帮助读者更好地理解和应用这些算法。
25 0
|
2月前
|
算法 容器
【算法】双指针
【算法】双指针
|
2月前
|
搜索推荐 算法 Java
插入排序算法(Java代码实现)
这篇文章通过Java代码示例详细解释了插入排序算法的实现过程,包括算法的基本思想、核心代码、辅助函数以及测试结果,展示了如何通过插入排序对数组进行升序排列。
|
26天前
|
存储 人工智能 C语言
C语言程序设计核心详解 第八章 指针超详细讲解_指针变量_二维数组指针_指向字符串指针
本文详细讲解了C语言中的指针,包括指针变量的定义与引用、指向数组及字符串的指针变量等。首先介绍了指针变量的基本概念和定义格式,随后通过多个示例展示了如何使用指针变量来操作普通变量、数组和字符串。文章还深入探讨了指向函数的指针变量以及指针数组的概念,并解释了空指针的意义和使用场景。通过丰富的代码示例和图形化展示,帮助读者更好地理解和掌握C语言中的指针知识。
|
2月前
|
C语言
【C初阶——指针5】鹏哥C语言系列文章,基本语法知识全面讲解——指针(5)
【C初阶——指针5】鹏哥C语言系列文章,基本语法知识全面讲解——指针(5)
下一篇
无影云桌面