#652 (Div. 2)D. TediousLee(畫圖找規律)

題目描述

Lee tried so hard to make a good div.2 D problem to balance his recent contest, but it still doesn’t feel good at all. Lee invented it so tediously slow that he managed to develop a phobia about div.2 D problem setting instead. And now he is hiding behind the bushes…
Let’s define a Rooted Dead Bush (RDB) of level n as a rooted tree constructed as described below.
A rooted dead bush of level 1 is a single vertex. To construct an RDB of level i we, at first, construct an RDB of level i−1, then for each vertex u:
if u has no children then we will add a single child to it;
if u has one child then we will add two children to it;
if u has more than one child, then we will skip it.
在這裏插入圖片描述
Rooted Dead Bushes of level 1, 2 and 3.
Let’s define a claw as a rooted tree with four vertices: one root vertex (called also as center) with three children. It looks like a claw:
在這裏插入圖片描述
The center of the claw is the vertex with label 1.
Lee has a Rooted Dead Bush of level n. Initially, all vertices of his RDB are green.
In one move, he can choose a claw in his RDB, if all vertices in the claw are green and all vertices of the claw are children of its center, then he colors the claw’s vertices in yellow.
He’d like to know the maximum number of yellow vertices he can achieve. Since the answer might be very large, print it modulo 109+7.

Input

The first line contains one integer t (1≤t≤104) — the number of test cases.
Next t lines contain test cases — one per line.
The first line of each test case contains one integer n (1≤n≤2⋅106) — the level of Lee’s RDB.

Output

For each test case, print a single integer — the maximum number of yellow vertices Lee can make modulo 109+7.

Example

input
7
1
2
3
4
5
100
2000000
output
0
0
4
4
12
990998587
804665184

Note

It’s easy to see that the answer for RDB of level 1 or 2 is 0.
The answer for RDB of level 3 is 4 since there is only one claw we can choose: {1,2,3,4}.
The answer for RDB of level 4 is 4 since we can choose either single claw {1,3,2,4} or single claw {2,7,5,6}. There are no other claws in the RDB of level 4 (for example, we can’t choose {2,1,7,6}, since 1 is not a child of center vertex 2).
在這裏插入圖片描述
Rooted Dead Bush of level 4.

題目分析

這個題就是畫圖畫出來的,畫圖找一下規律即可。
在這裏插入圖片描述
這樣就能發現level i是由1個level i-1和2個level i-2組成的。即f[i]=f[i-1]+2 * f[i-2]。
注意:當i爲3的倍數時,f[i]=f[i-1]+2 * f[i-2]+4。

代碼如下
#include <iostream>
#include <cstdio>
#include <cmath>
#include <string>
#include <cstring>
#include <stack>
#include <map>
#include <unordered_map>
#include <queue>
#include <vector>
#include <set> 
#include <algorithm>
#include <iomanip>
#define LL long long
using namespace std;
const int N=2e6+5,mod=1e9+7;
LL f[N];
void init()
{
	f[3]=4;
	for(int i=4;i<N;i++)
	{
		if(i%3) f[i]=(f[i-1]+2*f[i-2]%mod)%mod;
		else f[i]=(f[i-1]+2*f[i-2]%mod+4)%mod;
	}
}
int main()
{
	init();
	int t;
	cin>>t;
	while(t--)
	{
		int n;
		cin>>n;
		cout<<f[n]<<endl;
	}
	return 0;
}
 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章