小红的子集取反
时间限制:C/C++/Rust/Pascal 1秒,其他语言2秒
空间限制:C/C++/Rust/Pascal 256 M,其他语言512 M
64bit IO Format: %lld

题目描述

小红拿到了一个数组,她准备选择若干元素乘以 -1,使得最终所有元素的和为 0。小红想知道最少需要选择多少个元素?

输入描述:

第一行输入一个正整数n,代表数组的大小。
第二行输入n个整数a_i,代表数组的元素。
1\leq n \leq 200
-200 \leq a_i \leq 200

输出描述:

如果无法使得最终所有元素之和为 0,则输出 -1。
否则输出一个整数,代表选择元素的最小数量。
示例1

输入

复制
3
1 -2 3

输出

复制
1

说明

选择第一个元素即可。
示例2

输入

复制
3
2 -2 3

输出

复制
-1