同向双指针高阶题总结

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

相关文章

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Nginx Location映射规则总结归纳与最佳实践

《NginxLocation映射规则总结归纳与最佳实践》Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程,下面给大家介绍NginxLocation映射规则... 目录一、Location匹配规则与优先级1. 匹配模式2. 优先级顺序3. 匹配示例二、Proxy_pa

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

Java空指针异常NullPointerException的原因与解决方案

《Java空指针异常NullPointerException的原因与解决方案》在Java开发中,NullPointerException(空指针异常)是最常见的运行时异常之一,通常发生在程序尝试访问或... 目录一、空指针异常产生的原因1. 变量未初始化2. 对象引用被显式置为null3. 方法返回null

MySQL基本查询示例总结

《MySQL基本查询示例总结》:本文主要介绍MySQL基本查询示例总结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Create插入替换Retrieve(读取)select(确定列)where条件(确定行)null查询order by语句li

Linux区分SSD和机械硬盘的方法总结

《Linux区分SSD和机械硬盘的方法总结》在Linux系统管理中,了解存储设备的类型和特性是至关重要的,不同的存储介质(如固态硬盘SSD和机械硬盘HDD)在性能、可靠性和适用场景上有着显著差异,本文... 目录一、lsblk 命令简介基本用法二、识别磁盘类型的关键参数:ROTA查询 ROTA 参数ROTA

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

go 指针接收者和值接收者的区别小结

《go指针接收者和值接收者的区别小结》在Go语言中,值接收者和指针接收者是方法定义中的两种接收者类型,本文主要介绍了go指针接收者和值接收者的区别小结,文中通过示例代码介绍的非常详细,需要的朋友们下... 目录go 指针接收者和值接收者的区别易错点辨析go 指针接收者和值接收者的区别指针接收者和值接收者的