同向双指针高阶题总结

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

相关文章

Python中实现进度条的多种方法总结

《Python中实现进度条的多种方法总结》在Python编程中,进度条是一个非常有用的功能,它能让用户直观地了解任务的进度,提升用户体验,本文将介绍几种在Python中实现进度条的常用方法,并通过代码... 目录一、简单的打印方式二、使用tqdm库三、使用alive-progress库四、使用progres

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Java向kettle8.0传递参数的方式总结

《Java向kettle8.0传递参数的方式总结》介绍了如何在Kettle中传递参数到转换和作业中,包括设置全局properties、使用TransMeta和JobMeta的parameterValu... 目录1.传递参数到转换中2.传递参数到作业中总结1.传递参数到转换中1.1. 通过设置Trans的

C# Task Cancellation使用总结

《C#TaskCancellation使用总结》本文主要介绍了在使用CancellationTokenSource取消任务时的行为,以及如何使用Task的ContinueWith方法来处理任务的延... 目录C# Task Cancellation总结1、调用cancellationTokenSource.

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

二分最大匹配总结

HDU 2444  黑白染色 ,二分图判定 const int maxn = 208 ;vector<int> g[maxn] ;int n ;bool vis[maxn] ;int match[maxn] ;;int color[maxn] ;int setcolor(int u , int c){color[u] = c ;for(vector<int>::iter

整数Hash散列总结

方法:    step1  :线性探测  step2 散列   当 h(k)位置已经存储有元素的时候,依次探查(h(k)+i) mod S, i=1,2,3…,直到找到空的存储单元为止。其中,S为 数组长度。 HDU 1496   a*x1^2+b*x2^2+c*x3^2+d*x4^2=0 。 x在 [-100,100] 解的个数  const int MaxN = 3000