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;
}
相关推荐
m0_629494732 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户2 小时前
用队列实现栈
数据结构·算法
做人求其滴2 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
daad7773 小时前
记一组无人机IMU传感器数据
算法
计算机安禾3 小时前
【c++面向对象编程】第42篇:模板特化与偏特化:为特定类型定制实现
开发语言·c++·算法
小O的算法实验室3 小时前
2026年KBS,流形感知强化学习差分进化算法+不规则3D无人机路径规划,深度解析+性能实测
算法·智能算法·智能算法改进
玖釉-3 小时前
C++ 中的循环语句详解:while、do...while、for、嵌套循环与循环控制
开发语言·c++·算法
不做无法实现的梦~3 小时前
运动控制系统复习一览-----常考题目总结版本
算法
小短腿的代码世界3 小时前
信号路由风暴:Qt算法交易系统的高频信号分发架构
qt·算法·架构
阿文的代码库3 小时前
一文读懂GROUP BY 1,2 VS GROUP BY column_1, column_2 的区别
算法