0
点赞
收藏
分享

微信扫一扫

【记录】Excel|Excel 打印成 PDF 页数太多怎么办

 和为 K 的子数组

        题目解析

        算法讲解 

        编写代码

class Solution {
public int subarraySum(int[] nums, int k) {
// 创建哈希表标记前缀和出现的次数
Map<Integer, Integer> hash = new HashMap<>();
hash.put(0, 1);

int sum = 0, count = 0;
for (int i = 0; i < nums.length; i++) {
sum += nums[i];
count += hash.getOrDefault(sum - k, 0);
hash.put(sum, hash.getOrDefault(sum, 0) + 1);
}
return count;
}
}

和可被 K 整除的子数组

        题目解析

        算法讲解 

        编写代码 

class Solution {
public int subarraysDivByK(int[] nums, int k) {
// 存放前缀和的余数以及出现的次数
Map<Integer, Integer> hash = new HashMap<>();
hash.put(0, 1);

// 根据同余定理
int sum = 0, count = 0;
for (int x: nums) {
sum += x; // 计算当前位置的前缀和
int mod = (sum % k + k) % k; // Java取模的特殊性,当被除数为负数时取模结果为负数,需要纠正
count += hash.getOrDefault(mod, 0);
hash.put(mod, hash.getOrDefault(mod, 0) + 1);
}
return count;
}
}

连续数组

        题目解析

        算法讲解 

        编写代码 

class Solution {
public int findMaxLength(int[] nums) {
// 存放前缀和和对应的下标
Map<Integer, Integer> hash = new HashMap<>();
hash.put(0, -1); // 前缀和为0所对应的下标应该为-1

// 转化为和为0的子数组
int sum = 0, len = 0;
for (int i = 0; i < nums.length; i++) {
sum += nums[i] == 0 ? -1 : 1; // 将所有的0转化为-1
// 不需要每次都更新key为sum的值,只需更新一次即可
if (hash.containsKey(sum)) len = Math.max(len, i - hash.get(sum)); // 存在与当前sum相同的前缀和,则更新数据
else hash.put(sum, i); // 不存在,则将其放入哈希表
}
return len;
}
}

矩阵区域和

        题目解析

        算法讲解 

        编写代码 

class Solution {
public int[][] matrixBlockSum(int[][] mat, int k) {
// 创建dp二维前缀和数组
int m = mat.length + 1, n = mat[0].length + 1;
int[][] dp = new int[m][n];
for (int i = 1; i < m; i++) {
for (int j = 1; j < n; j++) {
dp[i][j] = dp[i - 1][j] + dp[i][j-1] + mat[i - 1][j - 1] - dp[i-1][j-1];
}
}

int[][] answer = new int[m - 1][n - 1];
for (int i = 0; i < m - 1; i++) {
for (int j = 0; j < n - 1; j++) {
int x1 = Math.max(i - k, 0), x2 = Math.min(i + k, m - 2);
int y1 = Math.max(j - k, 0), y2 = Math.min(j + k, n - 2);
answer[i][j] = dp[x2 + 1][y2 + 1] - dp[x1][y2 + 1] - dp[x2 + 1][y1] + dp[x1][y1];
}
}
return answer;
}
}

举报

相关推荐

0 条评论