远端评测题 2000ms 512MiB

旅行(trip)

题目描述

给你一个长度为 nn 的数组 A=(a1,a2,,an)A = (a_1, a_2, \dots, a_n)

  • 1、从中选取一个 连续 的区间 [l,r](1lrn)[l, r] (1 \le l \le r \le n),得到数组 B=(al,al+1,,ar)B = (a_l, a_{l+1}, \dots, a_r)
  • 2、计算这个数组 BB前缀和 数组 C=(c1,c2,,ck)C = (c_1, c_2, \dots, c_k),其中
    • CC 数组的长度为:k=rl+1k=r-l+1
    • $c_i = \sum \limits_{j=1}^{i}B_j = B_1+B_2+B_3+\dots+B_i$

找出这样一个区间 [l,r][l, r],使其对应的前缀和序列 CC包含最多数量的 00。请输出这个最大数量。

输入格式

本题包含多组测试数据。

第一行输入一个正整数 TT,表示数据组数。

接下来包含 TT 组数据,每组数据的格式如下:

  • 第一行输入一个正整数 nn
  • 第二行输入 nn 个整数,表示温度序列 a1,a2,,ana_1, a_2, \dots, a_n

输出格式

对于每组测试数据:

  • 输出一行一个非负整数,表示最优情况下前缀和序列中 00 的最大数量。
2
5
-1 0 1 0 0
5
4 2 0 -2 9
3
1

提示

【样例解释 #1】

该样例共有 22 组测试数据。

对于第一组测试数据,温度序列为 A=[1,0,1,0,0]A = [-1, 0, 1, 0, 0]。最佳选择是选取从第 11 天到第 55 天的时间段,对应的子序列为 [1,0,1,0,0][-1, 0, 1, 0, 0]。其前缀和序列计算如下:

  • c1=1c_1 = -1
  • c2=1+0=1c_2 = -1 + 0 = -1
  • c3=1+0+1=0c_3 = -1 + 0 + 1 = 0
  • c4=1+0+1+0=0c_4 = -1 + 0 + 1 + 0 = 0
  • c5=1+0+1+0+0=0c_5 = -1 + 0 + 1 + 0 + 0 = 0

前缀和序列为 [1,1,0,0,0][-1, -1, 0, 0, 0],其中包含 3300。这是所有可能的时间段中能得到的最大数量,因此答案是 33

对于第二组测试数据,温度序列为 A=[4,2,0,2,9]A = [4, 2, 0, -2, 9]。最佳选择是选取从第 22 天到第 44 天的时间段,对应的子序列为 [2,0,2][2, 0, -2]。其前缀和序列计算如下:

  • c1=2c_1 = 2
  • c2=2+0=2c_2 = 2 + 0 = 2
  • c3=2+0+(2)=0c_3 = 2 + 0 + (-2) = 0

前缀和序列为 [2,2,0][2, 2, 0],其中包含 1100。这是所有可能的时间段中能得到的最大数量,因此答案是 11

【数据范围】

对于 100%100\% 的数据,保证 1T51 \le T \le 51n1061 \le n \le 10^6106ai106-10^6 \le a_i \le 10^6

VV 为所有 aia_i 的绝对值的最大值,即 maxi=1nai\max \limits_{i=1}^{n} |a_i|

测试点编号 nn \le VV \le 特殊性质
1,21,2 1010 10610^6
363 \sim 6 500500
7107 \sim 10 50005000
111411 \sim 14 10510^5 11
15,1615,16 10610^6 A
17,1817,18 B
1919
2020 10610^6
  • 特殊性质 A:保证 n=105n = 10^5,且序列 AA 随机生成。随机方式是在所有符合数据范围的序列 AA 中,等概率均匀随机抽取得到输入时的序列 AA
  • 特殊性质 B:保证对于每个 i[1,n]i \in [1,n]ai0a_i \ge 0
  • 参考答案