当前位置: 首页 > wzjs >正文

wordpress制作游戏西安seo引擎搜索优化

wordpress制作游戏,西安seo引擎搜索优化,高品质网站建设,深圳疫情最新消息今天又封了吗每日算法学习 今天学习了两道关于子数组和的 LeetCode 题目。 1524. 和为奇数的子数组数目 题目 思路 💡 前缀和 核心思想:子数组 arr[i..j] 的和可以表示为两个前缀和之差,即 prefixSum[j1] - prefixSum[i] (假设 prefixSum[k] 表示 arr[0…

每日算法学习

今天学习了两道关于子数组和的 LeetCode 题目。


1524. 和为奇数的子数组数目

题目

Problem 1524 Screenshot

思路 💡

前缀和

核心思想:子数组 arr[i..j] 的和可以表示为两个前缀和之差,即 prefixSum[j+1] - prefixSum[i] (假设 prefixSum[k] 表示 arr[0...k-1] 的和,且 prefixSum[0] = 0)。

我们希望这个差为奇数。根据奇偶性运算规则:

  • 奇数 - 偶数 = 奇数
  • 偶数 - 奇数 = 奇数

这意味着,如果当前的前缀和 P_current 是奇数,我们需要查找在它之前出现过的偶数前缀和的个数。反之,如果 P_current 是偶数,我们需要查找之前出现过的奇数前缀和的个数。

解题过程 ⚙️

  1. 计算前缀和数组 prefixprefix[k] 存储原数组 arr 从索引 0k-1 的元素之和。特别地,prefix[0] 通常设为 0,代表空数组的和。
  2. 遍历计算出的每一个前缀和 x (从 prefix[0] 开始):
    • 我们用一个 Map map 来存储已遍历过的前缀和中,奇数和偶数各自出现的次数。在代码中,map 的键 true 代表奇数前缀和的计数,false 代表偶数前缀和的计数。
    • 对于当前前缀和 x
      • 如果 x奇数:我们需要找到一个之前的偶数前缀和 P_prev_even,使得 x - P_prev_even 为奇数。此时,结果 ret 加上 map 中记录的偶数前缀和的个数。
      • 如果 x偶数:我们需要找到一个之前的奇数前缀和 P_prev_odd,使得 x - P_prev_odd 为奇数。此时,结果 ret 加上 map 中记录的奇数前缀和的个数。
    • 更新 map:将当前前缀和 x 的奇偶性对应的计数加 1。
  3. 初始状态:prefix[0] = 0 是一个偶数。所以在遍历开始前(或者说,在处理 prefix[0] 时),偶数前缀和的计数为 1,奇数前缀和的计数为 0。代码中通过先查询后更新的方式,巧妙地处理了这一点:当处理 prefix[0]=0 (偶数)时,它会查询奇数前缀和的个数(初始为0,所以 ret 不变),然后将偶数前缀和的个数更新为1。

复杂度 📈

  • 时间复杂度: O ( N ) O(N) O(N),其中 N 是数组 arr 的长度。计算前缀和需要 O ( N ) O(N) O(N),遍历前缀和数组也需要 O ( N ) O(N) O(N)
  • 空间复杂度: O ( N ) O(N) O(N),主要用于存储前缀和数组 prefixmap 的空间是 O ( 1 ) O(1) O(1),因为它只存储两个键值对。

Code

class Solution {public int numOfSubarrays(int[] arr) {long ret = 0;int n = arr.length;final int MOD = 1_000_000_007;int[] prefix = new int[n + 1];Map<Boolean, Integer> map = new HashMap<>(n + 1); // true - 奇数   false - 偶数for (int i = 0; i < n; i++) {prefix[i + 1] = prefix[i] + arr[i];}for (int x : prefix) {// key 为奇数就去找偶数有多少个  key为偶数就去找奇数有多少个boolean key =  (x % 2 == 0);ret = (ret + map.getOrDefault(key, 0)) % MOD;// 存进map时注意取反map.put(!key, map.getOrDefault(!key, 0) + 1);}return (int) ret;}
}

974. 和可被 K 整除的子数组

题目

Problem 974 Screenshot

思路 💡

前缀和 + 同余定理

核心思想:子数组 nums[i..j] 的和为 S = prefixSum[j+1] - prefixSum[i]
我们希望 S 能被 K 整除,即 S % K == 0

根据同余定理,如果 (A - B) % K == 0,那么 A % K == B % K

应用到这里:(prefixSum[j+1] - prefixSum[i]) % K == 0 等价于 prefixSum[j+1] % K == prefixSum[i] % K

因此,我们只需要统计具有相同余数的前缀和出现的次数。

注意处理负数取模:在 Java (以及很多语言)中,负数对正数取模的结果可能是负数 (例如 -1 % 5 = -1)。为了确保余数始终在 [0, K-1] 区间内,我们通常使用 (sum % K + K) % K

解题过程 ⚙️

  1. 初始化一个变量 prefixSum = 0 (表示当前累积的前缀和) 和结果 ret = 0
  2. 使用一个数组map来存储每个前缀和模 K余数出现的次数。map[rem] 表示余数 rem 已经出现了多少次。
  3. 关键初始化map[0] = 1。这非常重要!它代表在开始遍历数组之前,我们有一个“空前缀和”(值为0),其模 K 的余数是 0。这能够正确处理那些从数组第一个元素开始其和就能被 K 整除的子数组。
  4. 遍历数组 nums 中的每个元素 num:
    a. 更新 prefixSum += num
    b. 计算当前 prefixSumK 的余数:remainder = (prefixSum % K + K) % K
    c. 在 map 中查找这个 remainder 之前已经出现过的次数,计为 count = map[remainder]。这意味着有 count 个之前的某个前缀和 P_prev 满足 P_prev % K == remainder。对于每一个这样的 P_prev,子数组 (P_current - P_prev) 都能被 K 整除。所以,将 count 加到 ret 上:ret += count
    d. 然后,将当前 prefixSum 的余数 remainder 计入 mapmap[remainder]++

复杂度 📈

  • 时间复杂度: O ( N ) O(N) O(N),其中 N 是数组 nums 的长度。我们只遍历数组一次。
  • 空间复杂度: O ( K ) O(K) O(K)map 数组的大小固定为 K,用于存储余数的计数。

Code

class Solution {public int subarraysDivByK(int[] nums, int k) {int ret = 0, prefix = 0;int[] map = new int[k];map[0] = 1; // prefix[i] % k = 0的情况for (int num : nums) {prefix += num;ret += map[(prefix % k + k) % k]++;}return ret;}
}

http://www.dtcms.com/wzjs/213732.html

相关文章:

  • 帝国做的网站怎么上传百度知道个人中心
  • 上网站 ftp双桥seo排名优化培训
  • 360网站提交收录网址沈阳seo公司
  • 人大网站建设的成效企业网站快速建站
  • 网站开发提供图片加载速度百度网站快速优化
  • 手机网站绑定域名地址查询
  • 源码之家关闭了合肥网络优化公司有几家
  • dw做网站教程海外推广方法有哪些
  • 广西南宁网站推广日本域名注册
  • 万维网网站301重定向怎么做网站建设哪家好
  • 广州定制网站公司公司网站
  • 佛山网站建设与设计公司seo网络推广知识
  • 杭州做网站公司有哪些鹤壁seo推广
  • 如何用vps建网站企业网站推广
  • 首饰网站建设网上电商平台开发
  • 绑定域名后 wordpress简述什么是seo及seo的作用
  • 常青花园做网站的公司网络营销策划书案例
  • 常州做网站代理商关键词自动优化
  • 网站的建设和维护成本站长工具收录
  • wordpress网站价格南宁seo优化公司排名
  • 网店网站建设的步骤过程北京seo推广优化
  • 做网站得做多少网页深圳市社会组织总会
  • 戴尔网站建设和维护代运营哪家比较可靠
  • 网站建设的开发工具举例网络营销的例子
  • 官方网站建设的公司淘宝指数查询官网
  • 东莞凤岗网站建设制作seo快速排名上首页
  • 南京品牌网站设计进行网络推广
  • 做网站用的幻灯片大小网站设计制作公司
  • 成都的建站公司厦门seo屈兴东
  • 宁波白云医院网站建设百度 营销怎么收费