3894 - 子集统计

题目描述

N 个小朋友坐成一排,他们的位置编号为 1, \dots , N,他们的年龄分别是 A_1,\dots,A_n

请编程计算出,如果从 N 个小朋友中挑选出 K (1 \le K \le N) 个小朋友,将他们的年龄进行按位或运算,能得到的最大值 Max 是多少?

同时,你还需要计算出,N 个小朋友中,有多少种不同的挑选方案,可以使得该方案中挑选的小朋友们的年龄进行按位或运算,也能得到 Max

如果某方案和另一个方案挑选的是不同位置的小朋友,那么这两个方案就认为是不同的方案。

输入

1 行输入整数 N,代表共有 N 位小朋友。

2 行输入 N 个整数,代表每个小朋友的年龄。

输出

输出 2 行。

1 行输出一个整数,代表选出若干小朋友将年龄做按位或运算的最大值 Max

2 行输出一个整数,代表有多少种不同的挑选方案,可以使得该方案中挑选的小朋友们的年龄做按位或运算,也可以得到第 1 行输出的最大值。

样例

输入

3
5 1 1

输出

5
4

输入

4
10 10 10 10

输出

10
15

输入

5
3 1 2 4 5

输出

7
17
说明

样例 1 解释

3 个数选若干数做按位或的最大值为 5

可以选择如下方案:

  1. 3 个数都选:5|1|1=5

  2. 选择第 1 个数 5,结果只能为 5

  3. 选择第 1 个数和第 2 个数:5|1=5

  4. 选择第 1 个数和第 3 个数:5|1=5

共有 4 种不同的选择方案。

数据范围

对于 100\% 的数据,1 \le N \le 181 \le A_i \le 10^5

标签
题目参数
时间限制 1 秒
内存限制 512 MB
提交次数 0
通过人数 0
金币数量 2 枚
难度 基础


上一题 下一题