LeetCode 2799、2840题解

使用hashmap加滑动窗口解决问题

例如List[1,3,1,2,2]

我们通过hashmap.put(nums[i],hashmap.getOrDefault(nums[i],0)+1)后再通过hashmap.size()获取键值对的数量,即不同值的数量。

滑动窗口思想如上所示:

复制代码
class Solution {

    public int countCompleteSubarrays(int[] nums) {

        int n = 0;

        HashMap<Integer,Integer> map = new HashMap<>();

        for(int i=0;i<nums.length;i++){

            map.put(nums[i],map.getOrDefault(nums[i],0)+1);

        }

        n = map.size();

        System.out.println("n:"+n);

  

        int left = 0;

        int right = n;

        int total = 0;

        while(right<=nums.length){

            HashMap<Integer,Integer> hashmap = new HashMap<>();

            for(int i=left;i<nums.length;i++){

                hashmap.put(nums[i],hashmap.getOrDefault(nums[i],0)+1);

                if(hashmap.size()==n) total++;

            }

            left++;

            right = n+left;

        }

        return total;

    }

}

如图所示为一种解决方法,也可以使用二维数组解决

复制代码
class Solution {

    public boolean checkStrings(String s1, String s2) {

        int[][] cnt1 = new int[2][26];

        int[][] cnt2 = new int[2][26];

        for (int i = 0; i < s1.length(); i++) {

            cnt1[i % 2][s1.charAt(i) - 'a']++;

            cnt2[i % 2][s2.charAt(i) - 'a']++;

        }

        return Arrays.deepEquals(cnt1, cnt2);

    }

}
相关推荐
hh随便起个名6 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
写写闲篇儿6 小时前
微软面试之白板做题
面试·职场和发展
Dingdangcat867 小时前
城市交通多目标检测系统:YOLO11-MAN-FasterCGLU算法优化与实战应用_3
算法·目标检测·目标跟踪
tang&8 小时前
滑动窗口:双指针的优雅舞步,征服连续区间问题的利器
数据结构·算法·哈希算法·滑动窗口
拼命鼠鼠8 小时前
【算法】矩阵链乘法的动态规划算法
算法·矩阵·动态规划
LYFlied8 小时前
【每日算法】LeetCode 17. 电话号码的字母组合
前端·算法·leetcode·面试·职场和发展
式5169 小时前
线性代数(八)非齐次方程组的解的结构
线性代数·算法·机器学习
橘颂TA10 小时前
【剑斩OFFER】算法的暴力美学——翻转对
算法·排序算法·结构与算法
叠叠乐10 小时前
robot_state_publisher 参数
java·前端·算法
hweiyu0010 小时前
排序算法:冒泡排序
算法·排序算法