CF1253B.Silly Mistake

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

The Central Company has an office with a sophisticated security system. There are 10610^6 employees, numbered from 11 to 10610^6 .

The security system logs entrances and departures. The entrance of the ii -th employee is denoted by the integer ii , while the departure of the ii -th employee is denoted by the integer i-i .

The company has some strict rules about access to its office:

  • An employee can enter the office at most once per day.
  • He obviously can't leave the office if he didn't enter it earlier that day.
  • In the beginning and at the end of every day, the office is empty (employees can't stay at night). It may also be empty at any moment of the day.

Any array of events satisfying these conditions is called a valid day.

Some examples of valid or invalid days:

  • [1,7,7,3,1,3][1, 7, -7, 3, -1, -3] is a valid day ( 11 enters, 77 enters, 77 leaves, 33 enters, 11 leaves, 33 leaves).
  • [2,2,3,3][2, -2, 3, -3] is also a valid day.
  • [2,5,5,5,5,2][2, 5, -5, 5, -5, -2] is not a valid day, because 55 entered the office twice during the same day.
  • [4,4][-4, 4] is not a valid day, because 44 left the office without being in it.
  • [4][4] is not a valid day, because 44 entered the office and didn't leave it before the end of the day.

There are nn events a1,a2,,ana_1, a_2, \ldots, a_n , in the order they occurred. This array corresponds to one or more consecutive days. The system administrator erased the dates of events by mistake, but he didn't change the order of the events.

You must partition (to cut) the array aa of events into contiguous subarrays, which must represent non-empty valid days (or say that it's impossible). Each array element should belong to exactly one contiguous subarray of a partition. Each contiguous subarray of a partition should be a valid day.

For example, if n=8n=8 and a=[1,1,1,2,1,2,3,3]a=[1, -1, 1, 2, -1, -2, 3, -3] then he can partition it into two contiguous subarrays which are valid days: a=[1,1  1,2,1,2,3,3]a = [1, -1~ \boldsymbol{|}~ 1, 2, -1, -2, 3, -3] .

Help the administrator to partition the given array aa in the required way or report that it is impossible to do. Find any required partition, you should not minimize or maximize the number of parts.

输入格式

The first line contains a single integer nn ( 1n1051 \le n \le 10^5 ).

The second line contains nn integers a1,a2,,ana_1, a_2, \ldots, a_n ( 106ai106-10^6 \le a_i \le 10^6 and ai0a_i \neq 0 ).

输出格式

If there is no valid partition, print 1-1 . Otherwise, print any valid partition in the following format:

  • On the first line print the number dd of days ( 1dn1 \le d \le n ).
  • On the second line, print dd integers c1,c2,,cdc_1, c_2, \ldots, c_d ( 1cin1 \le c_i \le n and c1+c2++cd=nc_1 + c_2 + \ldots + c_d = n ), where cic_i is the number of events in the ii -th day.

If there are many valid solutions, you can print any of them. You don't have to minimize nor maximize the number of days.

输入输出样例

  • 输入#1

    6
    1 7 -7 3 -1 -3
    

    输出#1

    1
    6
    
  • 输入#2

    8
    1 -1 1 2 -1 -2 3 -3
    

    输出#2

    2
    2 6
    
  • 输入#3

    6
    2 5 -5 5 -5 -2
    

    输出#3

    -1
    
  • 输入#4

    3
    -8 1 1
    

    输出#4

    -1
    

说明/提示

In the first example, the whole array is a valid day.

In the second example, one possible valid solution is to split the array into [1,1][1, -1] and [1,2,1,2,3,3][1, 2, -1, -2, 3, -3] ( d=2d = 2 and c=[2,6]c = [2, 6] ). The only other valid solution would be to split the array into [1,1][1, -1] , [1,2,1,2][1, 2, -1, -2] and [3,3][3, -3] ( d=3d = 3 and c=[2,4,2]c = [2, 4, 2] ). Both solutions are accepted.

In the third and fourth examples, we can prove that there exists no valid solution. Please note that the array given in input is not guaranteed to represent a coherent set of events.

首页