同向双指针高阶题总结

2024-09-04 14:08
文章标签 指针 总结 高阶 同向

本文主要是介绍同向双指针高阶题总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

有一类题,看起来很像同向双指针,但是不完全是,一般都是求exactly K

同向双指针教会了我们如何求at most K, 现在我们要求exactly K. 那么我们可以转换为 exactly K = atMost(K) - atMost(K - 1);

这类题有好多,如下:

Subarrays with K Different Integers 思路:跟 Substrings with exactly K distinct chars ,把问题转换为 at most k的count,这样就好做,然后用公式f(k) - f(k-1); 为什么这么做转换,是因为 同向双指针是 j 一直往前面走,j不能回头的,但是这个题目要求是要求所有的 diff integer  = k 的subarray;

[1,2,1,2]  k = 2这个为例: [1,2], [1,2,1], [1,2,1,2], [2,1,2], [1,2] 都是答案,但是j没办法回去;所以计算是有问题的;所以不能单单扫一遍,是计算不出来的; res += j - i ;  代表的是以  j -1 为结尾的,满足at most k chars的个数;

class Solution {public int subarraysWithKDistinct(int[] A, int K) {if(A == null || A.length == 0) {return 0;}return getAtMostK(A, K) - getAtMostK(A, K - 1);}private int getAtMostK(int[] A, int k) {int res = 0;int j = 0;int count = 0;int[] counts = new int[A.length + 1];for(int i = 0; i < A.length; i++) {// move j;while(j < A.length && count <= k) {if(counts[A[j]] == 0) {if(count == k) {break;}count++;}counts[A[j]]++;j++;}// update result;res += j - i;// move i;counts[A[i]]--;if(counts[A[i]] == 0) {count--;}}return res;}
}

Substrings of size K with K distinct chars 思路:这题思路很巧妙,我是看了上面那个 subarrays with k different integers 的花花视频才懂的。直接求很难,但是我们可以转换成 f(k) - f(k-1)  f(k)表示最多不大于k(at most k)的char的string的个数, at most k, 可以用sliding window的双指针来做,count 就是 j - i,表示以j - 1 为尾巴的subarray的个数;

public class numberOfUniqueChars {public int getAtMostKCharacters(String s, int k) {if(s == null || s.length() == 0) {return 0;}int j = 0;int[] counts = new int[256];int c = 0;int ans = 0;for(int i = 0; i < s.length(); i++) {// move j;while(j < s.length() && c <= k) {if(counts[s.charAt(j)] == 0 ) {if(c == k) {break;}c++;}counts[s.charAt(j)]++;j++;}//update result;ans += j - i;// remove i;counts[s.charAt(i)]--;if(counts[s.charAt(i)] == 0) {c--;}}return ans;}public static void main(String[]  args) {/*** Input: s = "pqpqs", k = 2Output: 7Explanation: ["pq", "pqp", "pqpq", "qp", "qpq", "pq", "qs"]* */numberOfUniqueChars numberOfUniqueChars = new numberOfUniqueChars();String s = "pqpqs";int ans1 = numberOfUniqueChars.getAtMostKCharacters(s, 2) - numberOfUniqueChars.getAtMostKCharacters(s, 1);// ans = 7;System.out.println("ans: " + ans1);}
}

Count Number of Nice Subarrays 思路:sliding window让我们学会了如何求At Most K的区间,那么Exactly K times = at most K times - at most K - 1 times

class Solution {public int numberOfSubarrays(int[] nums, int k) {if(nums == null || nums.length == 0) {return 0;}return getAtMostK(nums, k) - getAtMostK(nums, k - 1);}private int getAtMostK(int[] nums, int k) {// two pointers scan;int j = 0;int oddcount = 0;int res = 0;for(int i = 0; i < nums.length; i++) {// move j;while(j < nums.length && oddcount <= k) {if(nums[j] % 2 == 1) {if(oddcount == k) {break;}oddcount++;}j++;}//update resultres += j - i;//move i;if(nums[i] % 2 == 1) {oddcount--;}}return res;}
}

 

这篇关于同向双指针高阶题总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1136203

相关文章

Java Optional避免空指针异常的实现

《JavaOptional避免空指针异常的实现》空指针异常一直是困扰开发者的常见问题之一,本文主要介绍了JavaOptional避免空指针异常的实现,帮助开发者编写更健壮、可读性更高的代码,减少因... 目录一、Optional 概述二、Optional 的创建三、Optional 的常用方法四、Optio

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

java常见报错及解决方案总结

《java常见报错及解决方案总结》:本文主要介绍Java编程中常见错误类型及示例,包括语法错误、空指针异常、数组下标越界、类型转换异常、文件未找到异常、除以零异常、非法线程操作异常、方法未定义异常... 目录1. 语法错误 (Syntax Errors)示例 1:解决方案:2. 空指针异常 (NullPoi

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

Python依赖库的几种离线安装方法总结

《Python依赖库的几种离线安装方法总结》:本文主要介绍如何在Python中使用pip工具进行依赖库的安装和管理,包括如何导出和导入依赖包列表、如何下载和安装单个或多个库包及其依赖,以及如何指定... 目录前言一、如何copy一个python环境二、如何下载一个包及其依赖并安装三、如何导出requirem

解决java.lang.NullPointerException问题(空指针异常)

《解决java.lang.NullPointerException问题(空指针异常)》本文详细介绍了Java中的NullPointerException异常及其常见原因,包括对象引用为null、数组元... 目录Java.lang.NullPointerException(空指针异常)NullPointer

Rust格式化输出方式总结

《Rust格式化输出方式总结》Rust提供了强大的格式化输出功能,通过std::fmt模块和相关的宏来实现,主要的输出宏包括println!和format!,它们支持多种格式化占位符,如{}、{:?}... 目录Rust格式化输出方式基本的格式化输出格式化占位符Format 特性总结Rust格式化输出方式

Python中连接不同数据库的方法总结

《Python中连接不同数据库的方法总结》在数据驱动的现代应用开发中,Python凭借其丰富的库和强大的生态系统,成为连接各种数据库的理想编程语言,下面我们就来看看如何使用Python实现连接常用的几... 目录一、连接mysql数据库二、连接PostgreSQL数据库三、连接SQLite数据库四、连接Mo

Git提交代码详细流程及问题总结

《Git提交代码详细流程及问题总结》:本文主要介绍Git的三大分区,分别是工作区、暂存区和版本库,并详细描述了提交、推送、拉取代码和合并分支的流程,文中通过代码介绍的非常详解,需要的朋友可以参考下... 目录1.git 三大分区2.Git提交、推送、拉取代码、合并分支详细流程3.问题总结4.git push

Kubernetes常用命令大全近期总结

《Kubernetes常用命令大全近期总结》Kubernetes是用于大规模部署和管理这些容器的开源软件-在希腊语中,这个词还有“舵手”或“飞行员”的意思,使用Kubernetes(有时被称为“... 目录前言Kubernetes 的工作原理为什么要使用 Kubernetes?Kubernetes常用命令总