【算法小白周赛1E】ET表题解与代码(算法与数据结构刷题计划)

文章讨论了一种名为ET表的特殊数据结构,其操作包括区间减去,用于测试如何通过这些操作使给定数组所有元素变为0。文章提供了解题思路,涉及差分数组的应用和判断数组是否可归零的方法,以及给出样例分析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目链接:https://www.starrycoding.com/contest/3/E

题目描述

小e发明了一种奇怪的数据结构——ET表,这一奇怪的数据结构有以下两种奇怪的操作:

  • 将前 i i i 个数减去 k k k
  • 将后 i i i 个数减去 k k k

为了测试ET表的性能,小e找来了一个长度为 n n n 数组 a a a,现在需要判断能否通过ET表的这两种操作将这个数组的每一个数都变成 0 0 0,以及最少的操作次数。

输入格式

第一行为一个正整数 T T T ( 1 ≤ T ≤ 1 0 6 1 \le T \le 10^6 1T106 ),表示测试用例个数。

对于每个测试用例:

第一行为一个正整数 n n n ( 1 ≤ n ≤ 1 0 6 1 \le n \le 10^6 1n106 ),表示数组长度;

第二行包含 n n n 个正整数 a 1 … a n a_1 \ldots a_n a1an ( 1 ≤ a i ≤ 1 0 6 1 \le a_i \le 10^6 1ai106 )

数据保证 ∑ n ≤ 1 0 6 \sum{n} \le 10^6 n10

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值