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;
}
相关推荐
芸忻17 小时前
day 13 第六章 二叉树 part01代码随想录算法训练营71期
数据结构·算法
2401_9001515417 小时前
C++中的桥接模式
开发语言·c++·算法
小O的算法实验室17 小时前
2026年IEEE TNSE SCI2区,基于预测的双阶段分布式任务分配方法+搜救场景中最大化任务分配,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
月流霜17 小时前
Midjourney 零基础控图七大参数
人工智能·算法·midjourney
luckycoding17 小时前
1487. 保证文件名唯一
数据结构·算法·leetcode
DeeGLMath17 小时前
从基础算法到机器学习的研究轨迹
人工智能·算法·机器学习
Barkamin17 小时前
冒泡排序的简单实现
java·算法·排序算法
_dindong17 小时前
【单调栈/队列&并查集&字符串哈希&Tire树】习题集锦
数据结构·c++·算法·哈希算法
独自破碎E17 小时前
【手撕真题】合并区间
算法
big_rabbit050217 小时前
[算法][力扣110]平衡二叉树
数据结构·算法·leetcode