第一眼似乎很困难,实际上非常简单(

好吧这题我做了一个小时(

首先期望具有线性性,我们转化为计算点对对答案的贡献。

发现相对位置一样的点对对答案的贡献是一样的。我们把相对位置一样的点对铃出来,乘了之后求和再计算贡献。

把点对拎出来是一个卷积,很容易做掉。

贡献考虑把两半边的方案数乘起来。

如果形如 \((y,y+i\bmod n)\) 的点对积之和为 \(g[i]\),有 \(i\) 个点的圆划分方案数为 \(f[i]\),前者加上强制连接 \((1,n)\) 的方案数为 \(t[i]\),那么答案为:

\[\frac{\sum_{i=1}^{n-1}g[i]t[i+1]t[n-i+1]}{4f[n]}
\]

容易得到 \(2t[i]=f[i]\),那么:

\[\frac{\sum_{i=1}^{n-1}g[i]f[i+1]f[n-i+1]}{8f[n]}
\]

\(g\) 很容易求得,考虑 \(f\)。

容易发现,\(f\) 相当于计算序列上若干条线段互不“相交”的方案数。容易发现不“相交”只有两种可能:包含或两条线段中间夹着空格。

我们直接考虑 GF。

容易写出 DP:

\[f[n]=2f[n-1]+\sum_{i=2}^{n-1}f[i]f[n-i]
\]

下面重新定义新的 \(f[n]\) 为旧的 \(f[n+1]\):

\[f[n]=2f[n-1]+\sum_{i=1}^{n-1}f[i]f[n-i]
\]
\[F(x)=2xF(x)+F^2(x)-2F(x)+2
\]
\[F(x)=\frac{3-2x\pm\sqrt{4x^2-12x+1}}{2}
\]

然后我们知道 \(F(0)=1\),所以试一下:

\[\frac{3+\sqrt{1}}{2}=2,\frac{3-\sqrt{1}}{2}=1
\]

所以应该是 \(F(x)=\frac{3-2x-\sqrt{4x^2-12x+1}}{2}\)。

如何求出 \(F(x)\)?我们实际上只需要求出 \(\sqrt{4x^2-12x+1}\)。

设 \(H(x)=\sqrt{4x^2-12x+1}\),然后求导列一个 ODE:

\[H'(x)=\frac{4x-6}{\sqrt{4x^2-12x+1}}
\]
\[H(x)=\frac{4x^2-12x+1}{4x-6}\times H'(x)
\]
\[(4x-6)H(x)=(4x^2-12x+1)H'(x)
\]
\[4H[n-1]-6H[n]=4(n-1)H[n-1]-12nH[n]+(n+1)H[n+1]
\]
\[H[n+1]=\frac{(12n-6)H[n]-4(n-2)H[n-1]}{n+1}
\]

递推即可。

#include<cstdio>
typedef unsigned ui;
const ui M=1<<19|1,G=3,mod=998244353;
ui n,f[M],g[M],c[M];
inline ui pow(ui a,ui b=mod-2){
ui ans(1);for(;b;b>>=1,a=1ull*a*a%mod)if(b&1)ans=1ull*ans*a%mod;return ans;
}
inline ui Add(const ui&a,const ui&b){
return a+b>=mod?a+b-mod:a+b;
}
inline ui Del(const ui&a,const ui&b){
return b>a?a-b+mod:a-b;
}
inline void swap(ui&a,ui&b){
ui c=a;a=b;b=c;
}
inline void DFT(ui*f,const ui&n){
static ui W[M];
for(ui len=n>>1;len>=1;len>>=1){
const ui&w1=pow(G,(mod-1>>1)/len);W[0]=1;W[1]=w1;
for(ui i=2;i<len;++i)W[i]=1ull*W[i-1]*w1%mod;
for(ui k=0;k<n;k+=len<<1){
ui*w=W,*fl=f+(k),*fr=f+(k|len);
for(ui i=0;i<len;++i){
const ui x=*fl,y=*fr;
*fl++=Add(x,y);*fr++=1ull**w++*Del(x,y)%mod;
}
}
}
}
inline void IDFT(ui*f,const ui&n){
static ui W[M];
for(ui len=1;len<n;len<<=1){
const ui&w1=pow(G,(mod-1>>1)/len);W[0]=1;W[1]=w1;
for(ui i=2;i<len;++i)W[i]=1ull*W[i-1]*w1%mod;
for(ui k=0;k<n;k+=len<<1){
ui*w=W,*fl=f+(k),*fr=f+(k|len);
for(ui i=0;i<len;++i){
const ui x=*fl,y=1ull**w++**fr%mod;
*fl++=Add(x,y);*fr++=Del(x,y);
}
}
}
const ui&inv=pow(n);
for(ui i=1;(i<<1)<n;++i)swap(f[i],f[n-i]);
for(ui i=0;i<n;++i)f[i]=1ull*f[i]*inv%mod;
}
signed main(){
ui len(1),ans(0);
scanf("%u",&n);c[0]=1;c[1]=1;
for(ui i=2;i<n;++i)c[i]=1ull*(mod-mod/i)*c[mod%i]%mod;
c[0]=1;c[1]=mod-6;
for(ui i=2;i<n;++i)c[i]=((12ull*i-18)*c[i-1]+(mod+12-4ull*i)*c[i-2])%mod*c[i]%mod;
for(ui i=0;i<n;++i)c[i]=mod-c[i];c[0]=(c[0]+3)%mod;c[1]=(c[1]-2)%mod;{
const ui&inv=mod+1>>1;
for(ui i=0;i<=n;++i)c[i]=1ull*c[i]*inv%mod;
}
for(ui i=0;i<n;++i)scanf("%u",f+i),g[i]=g[n+i]=f[i];
for(ui i=0;(i<<1|1)<n;++i)swap(f[i],f[n-i-1]);
while(len<n*3)len<<=1;
DFT(f,len);DFT(g,len);
for(ui i=0;i<len;++i)f[i]=1ull*f[i]*g[i]%mod;
IDFT(f,len);
for(ui i=1;i<n;++i)ans=(ans+1ull*c[i]*c[n-i]%mod*f[n+i-1])%mod;
printf("%u",1ull*ans*pow(8ull*c[n-1]%mod)%mod);
}

LGP6694题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

随机推荐

  1. @property中的copy关键字

    1.@property中的copy的作用 防止外界修改内部的值 @interface Person : NSObject @property (nonatomic, retain) NSString ...

  2. Mybatis返回插入数据的主键的两种方式

    方式一: 需要在映射文件中添加如下片段: <insert id="insertProduct" parameterType="domain.model.Produc ...

  3. 自定义滚动条样式-兼容IE

    滚动条样式设置 html部分: 1 <div id="scroll" style="width: 500px; height: 300px; border: 2px ...

  4. k8s集群中部署prometheus server

    1.概述 本文档主要介绍如何在k8s集群中部署prometheus server用来作为监控的数据采集服务器,这样做可以很方便的对k8s集群中的指标.pod的.节点的指标进行采集和监控. 2.下载镜像 ...

  5. 协程 & IO模型 & HTTP协议

    今日内容 进程池与线程池的基本使用 协程理论与实操 IO模型 前端简介 内容详细 一.进程池与线程池的基本使用 1.进程池与线程池的作用 为了保证计算机硬件安全的前提下,提升程序的运行效率 2.回调机 ...

  6. [LeetCode]14.最长公共前缀(Java)

    原题地址: longest-common-prefix 题目描述: 编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入:st ...

  7. Mybatis动态开发

    1.单表动态SQL之if 2.单表动态SQL之foreach 3.单表动态SQL之片段抽取 Sql 中可将重复的 sql 提取出来,使⽤时⽤ include 引⽤即可,最终达到 sql 重⽤的⽬的

  8. C# 给Word每一页设置不同图片水印

    Word中设置水印时,可加载图片设置为水印效果,但通常添加水印效果时,会对所有页面都设置成统一效果,如果需要对每一页或者某个页面设置不同的水印效果,则可以参考本文中的方法.下面,将以C#代码为例,对W ...

  9. Java老码农心得:卷了这么多年,您真的卷会了吗?

    前言 大家好,我是福隆苑居士,今天跟大家聊一下程序员在当下内卷成风的情况下,使用什么方法可以了解行业发展趋势,知道哪些该学,哪些可以略过,今年应该掌握什么,可以放弃什么,让自己时刻紧跟行业的步伐永不掉 ...

  10. Java诊断神器:Arthas常用功能

    最新原文:https://www.cnblogs.com/uncleyong/p/14944401.html Arthas是Alibaba开源的Java诊断工具,功能很强大,它是通过Agent方式来连 ...