B. Luntik and Subsequences

time limit per test

1 second

memory limit per test

256 megabytes

Luntik came out for a morning stroll and found an array a of length n. He calculated the sum s of the elements of the array (s=∑ni=1ai). Luntik calls a subsequence of the array a nearly full if the sum of the numbers in that subsequence is equal to s−1.

Luntik really wants to know the number of nearly full subsequences of the array a. But he needs to come home so he asks you to solve that problem!

A sequence x is a subsequence of a sequence y if x can be obtained from y by deletion of several (possibly, zero or all) elements.

Input

The first line contains a single integer t (1≤t≤1000) --- the number of test cases. The next 2⋅t lines contain descriptions of test cases. The description of each test case consists of two lines.

The first line of each test case contains a single integer n (1≤n≤60) --- the length of the array.

The second line contains n integers a1,a2,...,an (0≤ai≤109) --- the elements of the array a.

Output

For each test case print the number of nearly full subsequences of the array.

Example

Input

Copy

复制代码
5
5
1 2 3 4 5
2
1000 1000
2
1 0
5
3 0 2 1 1
5
2 1 0 3 0

Output

Copy

复制代码
1
0
2
4
4

Note

In the first test case, s=1+2+3+4+5=15, only (2,3,4,5) is a nearly full subsequence among all subsequences, the sum in it is equal to 2+3+4+5=14=15−1.

In the second test case, there are no nearly full subsequences.

In the third test case, s=1+0=1, the nearly full subsequences are (0) and () (the sum of an empty subsequence is 0).

解题说明:此题是一道模拟题,其实就是找出数列中1和0的个数,找规律能发现结果就是1的个数乘以2^(0的个数)。

cpp 复制代码
#include<stdio.h>
int main()
{
	long long int t, a[65], i;
	scanf("%lld", &t);
	a[0] = 0;
	for (i = 1; i <= 61; i++)
	{
		a[i] = 1 + a[i - 1] * 2;
	}
	while (t--)
	{
		long long int s = 0, ans = 0, b = 0, c = 0, n, x;
		scanf("%lld", &n);
		for (i = 0; i < n; i++)
		{
			scanf("%lld", &x);
			if (x == 1)
			{
				b++;
			}
			if (x == 0)
			{
				c++;
			}
		}
		if (b)
		{
			ans = b + a[c] * b;
		}
		printf("%lld\n", ans);
	}
	return 0;
}
相关推荐
菜鸡儿齐1 小时前
leetcode-括号生成
算法·leetcode·职场和发展
fs哆哆1 小时前
在VB.NET中,随机打乱列表顺序的算法与方法
算法·.net
pen-ai2 小时前
【Yolo系列】Yolov3 目标检测算法原理详解
算法·yolo·目标检测
田里的水稻2 小时前
EP_基于UWB和单线激光雷达的托盘转送
人工智能·算法·数学建模·机器人·自动驾驶
List<String> error_P2 小时前
DFS(深度优先搜索)
数据结构·算法·dfs
今儿敲了吗2 小时前
27| 魔法封印
数据结构·c++·笔记·学习·算法
honortech2 小时前
算法题中的 mid 中点问题
算法
今儿敲了吗2 小时前
30| 木材加工
数据结构·c++·笔记·学习·算法
WW_千谷山4_sch2 小时前
MYOJ_7789:(洛谷P3388)【模板】割点(割顶)(tarjan算法)
c++·算法·深度优先·图论