结论:(不妨假设$p_{1}<p_{n}$)$\{p_{i}\}$合法当且仅当$\exists 1\le i\le n-1$,使得$p_{1}\ge p_{i}$且$p_{i+1}\ge p_{n}$

充分性——

为了方便,在删除一个元素后,$i$和$n$也随之变化(指向原来的元素,若删除$p_{i}$或$p_{n}$会补充说明)

对$\{p_{1},p_{2},...,p_{i}\}$这个子问题不断删除(直至不能删除),显然最终必然是$p_{1}<p_{2}<...<p_{i}$(否则一定仍可以操作),同理可得后者也为$p_{i+1}>p_{i+2}>...>p_{n}$

如果$i\ge 3$或$i\le n-3$,不妨再删除$p_{i}$(并将$i$减小1)或删除$p_{i+1}$,重复此过程后即有$n-2\le i\le 2$,进而对$i$和$n$分类讨论,最终序列一定形如$\{2,1\},\{2,3,1\},\{1,3,2\}$或$\{2,1,4,3\}$,也即合法

必要性——

对$n$从小到大归纳,$n=2$时显然成立(取$i=1$即可)

考虑$n=k+1$时,反证若存在排列$\{p_{i}\}$合法但不存在$i$满足上述条件,假设其第一次删除的是$p_{i}$,由归纳假设删除后要存在$i$(满足上述条件),显然必然是$p_{1}\le p_{i-1}$且$p_{i+1}\ge p_{n}$

进而对$p_{i}$的值分类讨论,不难发现删除前也存在$i$,与假设矛盾,即得证

(类似地,在$p_{1}>p_{n}$时即要求$\exists 1\le i\le n-1$,使得$p_{1}\le p_{i}$且$p_{i+1}\le p_{n}$)

由于已经确定$p_{1}$,考虑枚举$p_{n}$(不妨仍假设$p_{1}<p_{n}$),并统计不合法的方案数——

将数分为三类,即$[1,p_{1}],(p_{1},p_{n}),[p_{n},n]$,那么即要求第三类数不接在第一类数的后面

初始序列中即有一个第一类数和第三类数(由于$n\ge 3$,这两个数一定不会相邻),并依次插入第2类、第1类和第3类数(注意顺序,并且要考虑初始的数),显然方案即
$$
(p_{n}-p_{1}-1)!\frac{(p_{n}-3)!}{(p_{n}-p_{1}-2)!}\frac{(n-p_{1}-2)!}{(p_{n}-p_{1}-2)!}=(p_{n}-p_{1}-1)\frac{(p_{n}-3)!(n-p_{1}-2)!}{(p_{n}-p_{1}-2)!}
$$

该式可以$o(1)$计算,但由于要枚举$p_{n}$,时间复杂度为$o(tn)$,无法通过

进一步的,枚举$k=p_{n}-p_{1}-2$​,原式即
$$
(n-p_{1}-2)!\sum_{k=0}^{n-p_{1}-2}\frac{(k+1)(k+p_{1}-1)!}{k!}\\=(n-p_{1}-2)!\left(\sum_{k=0}^{n-p_{1}-2}\frac{(k+p_{1}-1)!}{k!}+\sum_{k=0}^{n-p_{1}-2}\frac{(k+p_{1}-1)!}{(k-1)!}\right)\\=(n-p_{1}-2)!\left((p_{1}-1)!\sum_{k=0}^{n-p_{1}-2}{k+p_{1}-1\choose p_{1}-1}+p_{1}!\sum_{k=0}^{n-p_{1}-2}{k+p_{1}-1\choose p_{1}}\right)\\=(n-p_{1}-2)!\left((p_{1}-1)!{n-2\choose p_{1}}+p_{1}!{n-2\choose p_{1}+1}\right)
$$
类似地,可以得到$p_{n}<p_{1}$​的情况,答案为
$$
(p_{1}-3)!\left((n-p_{1})!{n-2\choose n-p_{1}+1}+(n-p_{1}+1)!{n-2\choose n-p_{1}+2}\right)
$$
时间复杂度为$o(t)$,可以通过

 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 1000005
4 #define mod 998244353
5 #define ll long long
6 int t,n,x,ans,fac[N],inv[N];
7 int C(int n,int m){
8 return (ll)fac[n]*inv[m]%mod*inv[n-m]%mod;
9 }
10 int main(){
11 fac[0]=inv[0]=inv[1]=1;
12 for(int i=1;i<N;i++)fac[i]=(ll)fac[i-1]*i%mod;
13 for(int i=2;i<N;i++)inv[i]=(ll)(mod-mod/i)*inv[mod%i]%mod;
14 for(int i=1;i<N;i++)inv[i]=(ll)inv[i-1]*inv[i]%mod;
15 scanf("%d",&t);
16 while (t--){
17 scanf("%d%d",&n,&x);
18 ans=fac[n-1];
19 if (x+2<=n){
20 int s=((ll)fac[x-1]*C(n-2,x)+(ll)fac[x]*C(n-2,x+1))%mod;
21 ans=(ans-(ll)fac[n-x-2]*s%mod+mod)%mod;
22 }
23 if (x>=3){
24 int s=((ll)fac[n-x]*C(n-2,n-x+1)+(ll)fac[n-x+1]*C(n-2,n-x+2))%mod;
25 ans=(ans-(ll)fac[x-3]*s%mod+mod)%mod;
26 }
27 printf("%d\n",ans);
28 }
29 return 0;
30 }

[atAGC054E]ZigZag Break的更多相关文章

  1. 【leetcode】ZigZag Conversion

    题目简述 The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows ...

  2. 6. ZigZag Conversion

    题目: The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows l ...

  3. leetcode problem 6 ZigZag Conversion

    The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like ...

  4. Binary Tree Zigzag Level Order Traversal (LeetCode) 层序遍历二叉树

    题目描述: Binary Tree Zigzag Level Order Traversal AC Rate: 399/1474 My Submissions Given a binary tree, ...

  5. [LeetCode] ZigZag Conversion [9]

    称号 The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows li ...

  6. 字符串按照Z旋转90度然后上下翻转的字形按行输出字符串--ZigZag Conversion

    The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like ...

  7. [Swift]LeetCode6. Z字形变换 | ZigZag Conversion

    The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like ...

  8. LeetCode: 103_Binary Tree Zigzag Level Order Traversal | 二叉树Zigzag层次遍历 | Medium

    本题也属于层次遍历的变形,不同之处在于其遍历的方法是交替进行的,形成一个ZigZag的曲线形式,如下: 代码如下: struct TreeNode { int val; TreeNode* left; ...

  9. C++ leetcode::ZigZag Conversion

    mmp,写完没保存,又得重新写.晚上写了简历,感觉身体被掏空,大学两年半所经历的事,一张A4纸都写不满,真是一事无成呢.这操蛋的生活到底想对我这个小猫咪做什么. 今后要做一个早起的好宝宝~晚起就诅咒自 ...

随机推荐

  1. 痞子衡嵌入式:我的三个小项目陆续上线恩智浦官方Github

    恍如眨眼间,痞子衡在飞思卡尔/恩智浦已经工作 8 年多了,前 5 年主要是在软件团队,最近 3 年在系统团队.所处团队不同,工作思维也不同,自从转到系统团队,开始跟客户打起交道,对待问题和解决问题的立 ...

  2. 树莓派3B上手一二

    树莓派3B上手一二 早些时间心血来潮买过一个树莓派,但是当时只是玩一玩,买来按照网上的教程摆弄了一下就闲置了.最近毕业设计,做时序数据分析的相关的工作,刚好想起能够用到树莓派+Node-RED来生成模 ...

  3. 牛逼的磁盘检查工具duf

    1.部署 wget https://github.com/muesli/duf/releases/download/v0.5.0/checksums.txt wget https://github.c ...

  4. 从零入门 Serverless | 企业级 CI/CD 工具部署 Serverless 应用的落地实践

    背景知识 通过以往几节课程的学习,相信大家对于 SAE 平台已经有了一定的了解.SAE 为客户免除了很多复杂的运维工作,开箱即用.按用量付费:与此同时 SAE 提供了丰富的 Open API,可以很容 ...

  5. Spring IOC Container原理解析

    Spring Framework 之 IOC IOC.DI基础概念 关于IOC和DI大家都不陌生,我们直接上martin fowler的原文,里面已经有DI的例子和spring的使用示例 <In ...

  6. NOIP模拟77

    前言 感觉最近太飘了,这次考试是挺好的一次打击(好像也不算是). 犯了一个智障错误(双向边一倍数组 100pts->30pts)别的就.. T1 最大或 解题思路 一开始我以为是一个找规律,然而 ...

  7. PAT (Basic Level) Practice (中文)1014 福尔摩斯的约会 (20分)

    1014 福尔摩斯的约会 (20分) 带侦探福尔摩斯接到一张奇怪的字条:我们约会吧! 3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hys ...

  8. [源码解析]PyTorch如何实现前向传播(2) --- 基础类(下)

    [源码解析]PyTorch如何实现前向传播(2) --- 基础类(下) 目录 [源码解析]PyTorch如何实现前向传播(2) --- 基础类(下) 0x00 摘要 0x01 前文回顾 0x02 Te ...

  9. [no code][scrum meeting] Alpha 10

    项目 内容 会议时间 2020-04-16 会议主题 用户管理第一版交付 会议时长 15min 参会人员 PM+后端组成员 $( "#cnblogs_post_body" ).ca ...

  10. [技术博客]WEB实现划词右键操作

    [技术博客]WEB实现划词右键操作 一.功能解释 简单地对题目中描述的功能进行解释:在浏览器中,通过拖动鼠标选中一个词(或一段文字),右键弹出菜单,且菜单为自定义菜单,而非浏览器本身的菜单.类似的功能 ...