UOJ Logo Universal Online Judge

UOJ

#300. 【CTSC2017】吉夫特

附件下载 统计

简单的题目,既是礼物,也是毒药。

B 君设计了一道简单的题目,准备作为 gift 送给大家。

输入一个长度为 n 的数列 a1,a2,,an

问有多少个长度大于等于 2 的不上升的子序列 ab1,ab2,,abk 满足

i=2k(abi1abi)mod2=(ab1ab2)×(ab2ab3)××(abk1abk)mod2>0

输出这个个数对 1000000007 取模的结果。

G 君看到题目后,为大家解释了一些基本概念。

我们选择任意多个整数 bi 满足

1b1<b2<<bk1<bkn

我们称 ab1,ab2,,abka 的一个子序列。

如果这个子序列同时还满足

ab1ab2abk1abk

我们称这个子序列是不上升的。

组合数 (nm) 是从 n 个互不相同的元素中取 m 个元素的方案数,具体计算方法如下:

(nm)=n!m!(nm)!=n×(n1)××2×1(m×(m1)××2×1)((nm)×(nm1)××2×1)

这里要特别注意,因为我们只考虑不上升子序列,所以在求组合数的过程中,一定满足 nm,也就是 (abi1abi) 中一定有 abi1abi

我们在这里强调取模 xmody 的定义:

xmody=xxy×y

其中 n 表示小于等于 n 的最大整数。

xmod2>0,就是在说x是奇数。

与此同时,经验告诉我们一个长度为 n 的序列,子序列个数有 O(2n) 个,所以我们通过对答案取模来避免输出过大。

B 君觉得 G 君说的十分有道理,于是再次强调了这些基本概念。

最后,G 君听说这个题是作为 gift 送给大家,她有一句忠告。

"Vorsicht, Gift!"

“小心……剧毒!”

输入格式

第一行一个整数n

接下来n行,每行一个整数,这n行中的第i行,表示ai

输出格式

一行一个整数表示答案。

样例一

input

4
15
7
3
1

output

11

样例二至样例九

见样例数据下载。

限制与约定

  • 对于前 10% 的测试点,n9,1ai13
  • 对于前 20% 的测试点,n17,1ai20
  • 对于前 40% 的测试点,n1911,1ai4000
  • 对于前 70% 的测试点,n2017
  • 对于前 85% 的测试点,n100084
  • 对于 100% 的测试点, 1n211985,1ai233333。所有的ai互不相同,也就是说不存在i,j同时满足1i<jnai=aj

时间限制:2s

空间限制:512MB

下载

样例数据下载