zoukankan      html  css  js  c++  java
  • 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 imes2^b)个区域,每个区域如果横竖剪开,最终会得到((2^a+1) imes (2^b+1))块纸(形状不一定一样),同时满足(a+b=n)。那么期望就是(E=Sigma^n_{a=1}frac{C^{a}_{n}}{2^n} imes (2^a+1) imes (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 imes 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
    ", (ksm(2, n) + 1 + ksm(3, n) * ksm(ksm(2, n - 1), mod - 2) % mod) % mod);
    	}
    	return 0;
    }
    
  • 相关阅读:
    if __name__ == '__main__' 该如何理解
    Github下载慢和下载过程中断等情况的解决方案
    Git下载安装及设置详细教程
    冒烟测试是什么?
    100道MySQL数据库经典面试题解析
    Linux 下ZooKeeper安装
    运用Docker+Jenkins+Nginx+Spring Boot 自动化部署项目
    linux本地远程上传&下载阿里云oss的shell脚本实现方法
    运行java项目shell简洁脚本
    阿里云oss利用工具上传图片文件
  • 原文地址:https://www.cnblogs.com/lipoicyclic/p/13441246.html
Copyright © 2011-2022 走看看