Loading

HDU6822 Paperfolding(思维/排列组合/逆元)

There is a piece of paper in rectangular shape with sufficient length and width (lay flat on the table). Execute an operation instruction according to a string of length n from left to right that only contains 4 different characters of L,R,U,D.

  1. L instruction means to fold it from left to right,

  2. R instruction means to fold from right to left,

  3. U instruction means to fold from top to bottom,

  4. D instruction means to fold in half from bottom to top.

Note that the operation is limited due to the limitation of the desktop. Namely, the fold operation is restricted. For example, if you fold the paper from left to right, you should let the left side overlap on the right side with no rotation.

Now, cut a knife horizontally (completely cut) at the center of the visible part of the paper, and then cut vertically (completely cut).

The number of pieces of the whole paper split is num(S).

See the example and the picture for better understanding.

Now given a nonnegative integer n, the string SS is generated from 4n different possible outcomes in equal probability. Find the expected value of the number of pieces of the paper which is split, that is E(num(S)) mod 998244353.

It can be shown that the answers can be represented by \(\frac{P}{Q}\), where P and Q are coprime integers, and print the value of P×Q−1 mod 998244353.

img

Input

The first line contains a single integer TT

(1≤T\(10^5\)), the number of testcases.

Each of the next T lines contains a number n ( 0≤n\(10^8\)).

Output

For each testcase, print the answer in one line.

Sample Input

2
0
1

Sample Output

4
6

首先我们注意到,左右折其实是等价的,上下折也是等价的。不妨设左右折了a次,上下折了b次,展开以后这些折痕总共把纸分成了\(2^a\times2^b\)个区域,每个区域如果横竖剪开,最终会得到\((2^a+1)\times (2^b+1)\)块纸(形状不一定一样),同时满足\(a+b=n\)。那么期望就是\(E=\Sigma^n_{a=1}\frac{C^{a}_{n}}{2^n}\times (2^a+1)\times (2^{n-a}+1)\),展开后可得\(E=2^n+1+\Sigma^n_{a=0}\frac{C^a_{n}}{2^a} +\frac{1}{2^n}\Sigma^{n}_{a=0}2^a\times C^a_n\),后面这两项可以用二项式定理化简,得到最终的式子为\(E=2^n+1+\frac{3^n}{2^{n-1}}\)。同样是分数取模,用到了快速幂和费马小定理。

#include <bits/stdc++.h>
#define mod 998244353
using namespace std;
long long ksm(long long x,long long y){
    long long a=1;
    while(y){
        if(y&1) a=a*x%mod;
        y>>=1;
        x=x*x%mod;
    }
    return a;
}
int main()
{
	int t;
	cin >> t;
	while(t--)
	{
		long long n;
		scanf("%lld", &n);
		if(!n) cout << 4 << endl;
		else printf("%lld\n", (ksm(2, n) + 1 + ksm(3, n) * ksm(ksm(2, n - 1), mod - 2) % mod) % mod);
	}
	return 0;
}
posted @ 2020-08-05 17:18  脂环  阅读(231)  评论(0编辑  收藏  举报