Leetcode 3354. Make Array Elements Equal to Zero

  • [Leetcode 3354. Make Array Elements Equal to Zero](#Leetcode 3354. Make Array Elements Equal to Zero)
    • [1. 解题思路](#1. 解题思路)
    • [2. 代码实现](#2. 代码实现)

1. 解题思路

这一题是一道easy的题目,本来没想写的,因为完全可以暴力搞定,不过这里还是写了一下,因为这道题多少还是比较巧妙的,问题的描述一大把,事实上就是要分析在什么条件下可以使得数组归零,而这个的回答就是要求:

  • 元素两侧的元素之和相同,此时往哪个方向开始均可以,有两种走法;
  • 元素两侧的元素之差为1,此时往多的那一侧行走可以归零,有且只有一种走法;

因此,这道题事实上就变成一个累计数组的题目了, O ( N ) O(N) O(N)的算法复杂度即可完成。

2. 代码实现

给出python代码实现如下:

python 复制代码
class Solution:
    def countValidSelections(self, nums: List[int]) -> int:
        s = sum(nums)
        pre = 0
        ans = 0
        for num in nums:
            left = pre
            right = s-pre-num
            if num == 0:
                if left == right:
                    ans += 2
                elif abs(left-right) == 1:
                    ans += 1
            pre += num
        return ans

提交代码评测得到:耗时48ms,占用内存16.7MB。

相关推荐
We་ct15 小时前
LeetCode 36. 有效的数独:Set实现哈希表最优解
前端·算法·leetcode·typescript·散列表
tod11315 小时前
力扣高频 SQL 50 题阶段总结(四)
开发语言·数据库·sql·算法·leetcode
iAkuya16 小时前
(leetcode)力扣100 57电话号码的字母组合(回溯)
算法·leetcode·深度优先
想进个大厂19 小时前
代码随想录day31 贪心05
数据结构·算法·leetcode
橘颂TA19 小时前
【剑斩OFFER】算法的暴力美学——力扣 207 题:课程表
数据结构·c++·算法·leetcode·职场和发展
有一个好名字20 小时前
力扣-迷宫中离入口最近的出口
算法·leetcode·职场和发展
踩坑记录20 小时前
leetcode hot100 226. 翻转二叉树 easy 递归 层序遍历 BFS
算法·leetcode·宽度优先
鱼跃鹰飞20 小时前
Leetcode会员尊享面试100题:333.最大二叉搜索子树
数据结构·算法·leetcode·面试
鱼跃鹰飞20 小时前
Leetcode会员尊享面试100题:255.验证二叉搜索树的前序遍历序列
算法·leetcode·面试
YuTaoShao21 小时前
【LeetCode 每日一题】744. 寻找比目标字母大的最小字母——(解法一)遍历
算法·leetcode·职场和发展