LeetCode 3432. 统计元素和差值为偶数的分区方案数

LeetCode 3432. 统计元素和差值为偶数的分区方案数

问题描述

给定一个数组 nums,需要将它分割成两个非空数组。对左子数组和右子数组先求元素和再做差,统计并返回差值为偶数的分区方案数。

前缀和的发现

用前缀和优化时间复杂度到 O(n),设前缀和数组为 s,其中 s[i] 表示前 i 个元素的和。

对于分割点 i(左半部分是 s[i],右半部分是 s[n-1]-s[i]):

差值 = s[i] - (s[n-1] - s[i]) = 2*s[i] - s[n-1]

现在观察差值的奇偶性:

  • 2*s[i] 一定是偶数(乘以2的结果)
  • 差值的奇偶性只取决于 s[n-1] 的奇偶性

关键发现s[i] - (s[n-1] - s[i]) 是否为偶数,只和总和 s[n-1] 的奇偶性有关!

最终解法

go 复制代码
func countPartitionsDiff(nums []int) int {
    sum := 0
    for _, v := range nums {
        sum += v
    }
    
    // 总和为奇数:差值一定为奇数,返回0
    // 总和为偶数:所有分割点都有效,返回 n-1
    if sum % 2 != 0 {
        return 0
    }
    return len(nums) - 1
}

复杂度分析

  • 时间复杂度:O(n),只需遍历一次求总和
  • 空间复杂度:O(1),常数级别额外空间

核心发现

差值为偶数的条件完全由总和的奇偶性决定,与具体的分割位置无关。

相关推荐
wangjialelele10 分钟前
平衡二叉搜索树:AVL树和红黑树
java·c语言·开发语言·数据结构·c++·算法·深度优先
驱动探索者27 分钟前
linux mailbox 学习
linux·学习·算法
ringking12330 分钟前
autoware-1:安装环境cuda/cudnn/tensorRT库函数的判断
人工智能·算法·机器学习
大闲在人1 小时前
8. 供应链与制造过程术语:产能
算法·制造·供应链管理·智能制造·工业工程
一只小小的芙厨1 小时前
寒假集训笔记·以点为对象的树形DP
c++·算法
历程里程碑1 小时前
普通数组----合并区间
java·数据结构·python·算法·leetcode·职场和发展·tornado
执风挽^1 小时前
Python基础编程题2
开发语言·python·算法·visual studio code
Z9fish2 小时前
sse哈工大C语言编程练习20
c语言·开发语言·算法
晓13132 小时前
第六章 【C语言篇:结构体&位运算】 结构体、位运算全面解析
c语言·算法
iAkuya2 小时前
(leetcode)力扣100 61分割回文串(回溯,动归)
算法·leetcode·职场和发展