NTT【51nod】1514 美妙的序列
题意:1~n 的全排列中,有多少个排列满足任意从中间切成两段后,左边段的最大值大于右边段的最小值?
例如:n为3时有3种
2 3 1
3 1 2
3 2 1
解释:比如 2 3 1
(2) (3 1) 1比2小
(2 3) (1) 1比2小
都满足上面的条件。
3 2 1
(3)(2 1) 1比3小
(32)(1) 1比3小
都满足上面的条件。
而2 1 3不满足,因为(2 1)(3),3比左边所有的数都大。
====================================分割线====================================
首先序列为美妙的等价于不存在(1<=i<n)使得 前i个数为1~i的排列
令f[n]为长度为n的答案
则:
f[0]=0
f[i]=i!-sigma(f[j]*(i-j)!) 0<=j<i
我们将其变形
Sigma(f[j]*(i-j)!) = i! i > 0, j=0~i
Sigma(f[j]*(i-j)!) = 0 i = 0, j=0~i
令G(x)=sigma(i!*x^i),F(x)=sigma(f[i]*x^i)
F(x)*G(x)=G(x)-1 (减一为i = 0的情况)
F(x)=(G(x)-1)/G(x)=1-1/G(x)
多项式求逆即可
#include<cstdio>
#include<iostream>
typedef long long ll;
using namespace std;
const int N = , K = ;
int n, m, i, k;
int a[N+], b[N+], tmp[N+], tmp2[N+];
int P = , G = , g[K+], ng[K+], inv[N+], inv2;
int pow(int a,int b){int t=;for(;b;b>>=,a=(ll)a*a%P)if(b&)t=(ll)t*a%P;return t;}
void NTT(int*a,int n,int t){
for(int i=,j=;i<n-;i++){
for(int s=n;j^=s>>=,~j&s;);
if(i<j)swap(a[i], a[j]);
}
for(int d=;(<<d)<n;d++){
int m=<<d,m2=m<<,_w=t==?g[d]:ng[d];
for(int i=;i<n;i+=m2)for(int w=,j=;j<m;j++){
int&A=a[i+j+m],&B=a[i+j],t=(ll)w*A%P;
A=B-t;if(A<)A+=P;
B=B+t;if(B>=P)B-=P;
w=(ll)w*_w%P;
}
}
if(t==-)for(int i=,j=inv[n];i<n;i++)a[i]=(ll)a[i]*j%P;
}
//给定a,求a的逆元b
void getinv(int*a,int*b,int n){
if(n==){b[]=pow(a[],P-);return;}
getinv(a,b,n>>);
int k=n<<,i;
for(i=;i<n;i++)tmp[i]=a[i];
for(i=n;i<k;i++)tmp[i]=b[i]=;
NTT(tmp,k,),NTT(b,k,);
for(i=;i<k;i++){
b[i]=(ll)b[i]*(-(ll)tmp[i]*b[i]%P)%P;
if(b[i]<)b[i]+=P;
}
NTT(b,k,-);
for(i=n;i<k;i++)b[i]=;
}
int main(){
for(g[K]=pow(G,(P-)/N),ng[K]=pow(g[K],P-),i=K-;~i;i--)
g[i]=(ll)g[i+]*g[i+]%P,ng[i]=(ll)ng[i+]*ng[i+]%P;
for(inv[]=,i=;i<=N;i++)inv[i]=(ll)(P-inv[P%i])*(P/i)%P;inv2=inv[];
int len = ;
while(len <= ) len <<= ;
a[] = ;
for(int i = ; i < len; i++)
a[i] = (ll)i*a[i-]%P;
getinv(a, b, len);
for(int i = ; i < len; i++)
b[i] = (-b[i]+P)%P;
b[]++;
int t, n; scanf("%d", &t);
while(t--){
scanf("%d", &n);
printf("%d\n", b[n]);
}
return ;
}
NTT【51nod】1514 美妙的序列的更多相关文章
- 51nod 1514 美妙的序列 分治NTT + 容斥
Code: #include<bits/stdc++.h> #define ll long long #define mod 998244353 #define maxn 400000 # ...
- 51nod 1514 美妙的序列
Description 长度为n的排列,且满足从中间任意位置划分为两个非空数列后,左边的最大值>右边的最小值.问这样的排列有多少个%998244353 题面 Solution 正难则反 \(f[ ...
- Solution -「51nod 1514」美妙的序列
\(\mathcal{Description}\) Link. 称排列 \(\{p_n\}\) 美妙,当且仅当 \((\forall i\in[1,n))(\max_{j\in[1,i]}\{ ...
- [51nod1514] 美妙的序列
Description 如果对于一个 \(1\sim n\) 的排列满足: 在 \(1\sim n-1\) 这些位置之后将序列断开,使得总可以从右边找一个数,使得该数不会比左边所有数都大,则称该序列是 ...
- 【51nod 1514】 美妙的序列
题目 我们发现我们得正难则反 还是设\(f_i\)表示长度为\(i\)的序列个数 考虑容斥 \[f_i=i!-\sum_{j=1}^{i-1}f_j(i-j)!\] \(i!\)显然是总方案数,我们减 ...
- FFT/NTT [51Nod 1028] 大数乘法 V2
题目链接:51Nod 传送门 没压位,效率会低一点 1.FFT #include <cstdio> #include <cstring> #include <algori ...
- 51nod 1510 最小化序列 | DP 贪心
题目描述 现在有一个长度为n的数组A,另外还有一个整数k.数组下标从1开始. 现在你需要把数组的顺序重新排列一下使得下面这个的式子的值尽可能小. ∑|A[i]−A[i+k]| 特别的,你也可以不对数组 ...
- 【51nod】1251 Fox序列的数量
题解 容斥题 我们枚举出现次数最多的数出现了K次 然后我们需要计算的序列是所有数字出现个数都不超过K - 1次 我们枚举不合法的数字的数目j,说明这个排列里除了我们固定出现K次的数至少有j个数是不合法 ...
- 【51nod 1251】 Fox序列的数量(以及带限制插板法讲解)
为什么网上没有篇详细的题解[雾 可能各位聚聚觉得这道题太简单了吧 /kk 题意 首先题目是求满足条件的序列个数,条件为:出现次数最多的数仅有一个 分析 感谢 刚睡醒的 JZ姐姐在咱写题解忽然陷入自闭的 ...
随机推荐
- JavaEE基础(九)
1.面向对象(多态的概述及其代码体现) A:多态(polymorphic)概述 事物存在的多种形态 B:多态前提 a:要有继承关系. b:要有方法重写. c:要有父类引用指向子类对象. C:案例演示 ...
- SQL编程之高级查询(子查询)以及注意事项
SQL编程之高级查询(子查询)以及注意事项 1.什么是子查询? 当一个查询是另一个查询的条件时,称之为子查询.子查询可以使用几个简单命令构造功能强大的复合命令.子查询最常用于SELECT-SQL命 ...
- php socket通信(tcp/udp)
注意 1.在socket_bind的时候ip地址不能真回环地址如127.0.0.1 2.server.php后台跑起来的时候 nohup php server.php > /var/tmp/a. ...
- Asp.net 与 jsp 交互 (打开或跳转页面)
//// 打开固定大小窗体 Response.Write("<script>window.open('Tree1_edit.aspx','child','width=300,he ...
- 如何修改配置以修复ThinkPad 小红帽滚轮失效?
本人使用ThinkPad X1 Carbon超级本,由于近期安装了遨游浏览器(Maxthon),发现其总体体验还是不错,但是在本机器上有个明显的Bug:就是小红帽的滚轮不管用. 由于就查了网上相关资料 ...
- wpf的研究和反思
WPF的研究和反思 目前是否适合使用wpf WPF(Windows Presentation Foundation)是微软推出的基于Windows Vista的用户界面框架,属于.NET F ...
- UVa 1339,紫书P73,词频
题目链接:https://uva.onlinejudge.org/external/13/1339.pdf 紫书P73 解题报告: #include <stdio.h> #include ...
- Poj(2679),SPFA,二级比较
题目链接:http://poj.org/problem?id=2679 嗯,思路清晰,先DFS看是不是通路,接着就是SPFA找最短路(路是费用,费用相同就比较路的长度). 超哥的代码还有一点问题,初始 ...
- 灰色预测模型 c# 算法实现
public class GrayModel { private double a0, a1, a2; private int size; priva ...
- Access SQL中Left Join、Right Join和Inner Join的使用
1.表结构 表A 表B 2.Left Join 示例:2.1 Select * From A left join B on A. ...