CF1696B.NIT Destroys the Universe
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
For a collection of integers S , define mex(S) as the smallest non-negative integer that does not appear in S .
NIT, the cleaver, decides to destroy the universe. He is not so powerful as Thanos, so he can only destroy the universe by snapping his fingers several times.
The universe can be represented as a 1-indexed array a of length n . When NIT snaps his fingers, he does the following operation on the array:
- He selects positive integers l and r such that 1≤l≤r≤n . Let w=mex({al,al+1,…,ar}) . Then, for all l≤i≤r , set ai to w .
We say the universe is destroyed if and only if for all 1≤i≤n , ai=0 holds.
Find the minimum number of times NIT needs to snap his fingers to destroy the universe. That is, find the minimum number of operations NIT needs to perform to make all elements in the array equal to 0 .
输入格式
Each test contains multiple test cases. The first line contains the number of test cases t ( 1≤t≤104 ). Description of the test cases follows.
The first line of each test case contains one integer n ( 1≤n≤105 ).
The second line of each test case contains n integers a1 , a2 , … , an ( 0≤ai≤109 ).
It is guaranteed that the sum of n over all test cases does not exceed 2⋅105 .
输出格式
For each test case, print one integer — the answer to the problem.
输入输出样例
输入#1
4 4 0 0 0 0 5 0 1 2 3 4 7 0 2 3 0 1 2 0 1 1000000000
输出#1
0 1 2 1
说明/提示
In the first test case, we do 0 operations and all elements in the array are already equal to 0 .
In the second test case, one optimal way is doing the operation with l=2 , r=5 .
In the third test case, one optimal way is doing the operation twice, respectively with l=4 , r=4 and l=2 , r=6 .
In the fourth test case, one optimal way is doing the operation with l=1 , r=1 .