算法基础-双指针算法

最长连续不重复子序列

  1. 双指针[j, i]维护的是以a[i]结尾的最长连续不重复子序列
  2. [j, i - 1]是前一步得到的最长连续不重复子序列,所以如果[j, i]中有重复元素,一定是a[i],所以[j, i - 1]中一定有一个数字与a[i]重复,因此右移j直到a[i]不重复(通过次数来判断)为止
  3. 数组s记录子序列a[j ~ i]中各元素出现次数

i移动到第二个9,次数为2,j 减去1 并且右移1位到3
i移动到第二个3,次数为2,j减去1并且右移1位到6

每次都是先减去1再右移,保证每个数字不重复

java 复制代码
public class Main {
    public static void main(String[] args) {
        int[] a = new int[1000001];
        int[] s = new int[1000001];
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();
        for(int i = 0; i < n; i ++)
            a[i] = in.nextInt();
        int res = 0;
        for(int i = 0, j = 0; i < n; i ++) {
            s[a[i]] ++;
            while(s[a[i]] > 1) {
                s[a[j]] --;
                j ++;
            }
            res = Math.max(res, i - j + 1);
        }
        System.out.println(res);
    }
}

数组元素的目标和

a数组选的值越大,那么b数组选的值越小,x是固定的

java 复制代码
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();
        int m = in.nextInt();
        int x = in.nextInt();
        int[] a = new int[n + 10];
        int[] b = new int[m + 10];
        for(int i = 0; i < n; i ++)
            a[i] = in.nextInt();
        for(int i = 0; i < m; i ++)
            b[i] = in.nextInt();
        for(int i = 0, j = m - 1; i < n; i ++) {
            while(a[i] + b[j] > x && j >= 0)
                j --;
            if(a[i] + b[j] == x && j >= 0) {
                System.out.println(i + " " + j);
                break;
            }
        }
    }
}

判断子序列

只需要找到一种情况即可
j 完全遍历一遍,找到的话 i 就往后移动一位,如果 i == n 说明全部找到

java 复制代码
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();
        int m = in.nextInt();
        int[] a = new int[n + 10];
        int[] b = new int[m + 10];
        for(int i = 0; i < n; i ++)
            a[i] = in.nextInt();
        for(int i = 0; i < m; i ++)
            b[i] = in.nextInt();
        int i = 0, j = 0;
        while(i < n && j < m) {
            if(a[i] == b[j])
                i ++;
            j ++;
        }
        if(i == n)
            System.out.println("Yes");
        else
            System.out.println("No");
    }
}
相关推荐
胖咕噜的稞达鸭6 分钟前
算法入门:专题攻克一---双指针(3)有效三角形的个数 查找总价格为目标值的两个商品(剑指offer题目)
算法
毕设源码-朱学姐2 小时前
【开题答辩全过程】以 爱心捐赠网站为例,包含答辩的问题和答案
java·eclipse
尘觉4 小时前
中秋节与 Spring Boot 的思考:一场开箱即用的团圆盛宴
java·spring boot·后端
逻辑留白陈4 小时前
Adaboost进阶:与主流集成算法对比+工业级案例+未来方向
算法
Learn Beyond Limits5 小时前
Mean Normalization|均值归一化
人工智能·神经网络·算法·机器学习·均值算法·ai·吴恩达
天选之女wow5 小时前
【代码随想录算法训练营——Day28】贪心算法——134.加油站、135.分发糖果、860.柠檬水找零、406.根据身高重建队列
算法·leetcode·贪心算法
Gohldg5 小时前
C++算法·贪心例题讲解
c++·数学·算法·贪心算法
Le1Yu5 小时前
2025-10-7学习笔记
java·笔记·学习
popoxf5 小时前
spring容器启动流程(反射视角)
java·后端·spring
远远远远子5 小时前
类与对象 --1
开发语言·c++·算法