首页 > 其他分享 >CF1542E2 题解

CF1542E2 题解

时间:2024-02-02 22:00:15浏览次数:47  
标签:G2 G1 题解 rep times CF1542E2 pi sum

一、题目描述

  设 $\pi (x)$ 为全排列 $x$ 的逆序对数。

  给定 $n,m$,求有多少对长度为 $n$ 的排列 $p,q$,使得 $p$ 的字典序小于 $q$,且 $\pi (p)>\pi (q)$

  答案对 $m$ 取模。数据范围:$1\le n\le 500,1\le m\le 10^9$。


 二、解题思路:

  一开始列出计算式个人感觉是最难的一步,后面化简多半就是套路了。

  因为字典序相较于逆序对数要简单一些,所以我们先考虑字典序。

  枚举排列 $p$ 在第 $i$ 个位置第一次比 $q$ 小,枚举 $i$ 位置上 $p,q$ 的大小,再考虑逆序对数。

  注意到前 $i-1$ 位不会对逆序对数之差造成任何影响,无论是内部还是对外都是这样。

  对于后面 $n-i$ 位的部分显然应该计数 $dp$,因为没有其他思路,数据范围也提示你了。

  设 $f_{i,j}$ 表示长度为 $i$ 的排列对 $(p,q)$ 满足 $\pi(p)-\pi(q)$ 的数量为 $j$ 的方案数。

   为什么这样设状态呢?因为我们对于每一个长度的 $(p,q)$ 都要统计答案,而且这样很好转移。

  显而易见的,$ans=\sum_{i=1}^n{n\choose n-i}\times (n-i)! \times (\sum_{j=1}^{lim}\sum_{p=1}^i\sum_{q=p+1}^if_{i-1,j-p+q})$

  注意这里枚举的 $i$ 与前面意义不一样,这里的 $i$ 是枚举的后面一部分的长度。

  显然我们需要做到对 $f$ 数组的 $O(1)$ 转移。先推一下式子:

  $f_{i,j}=\sum_{p=1}^i\sum_{q=1}^if_{i-1,j-p+q}$

  $=\sum_{p-q=1-i}^{i-1}f_{i-1,j-(p-q)}\times (i-\left| p-q\right|)$​​

  $=\sum_{\mid d \mid =0}^{i-1}f_{i-1,j-d}\times (i-\left|d\right|)$

  $=\sum_{d=1}^if_{i-1,j+d}\times (i-d)+\sum_{d=0}^{i-1}f_{i-1,j-d}\times (i-d)$

  $=S1_{i,j}+S2_{i,j}$($S1_{i,j},S2_{i,j}$ 分别代替上个式子中的两个部分)

  $S1_{i,j}=\sum_{d=1}^{i}f_{i-1,j+d}\times i-\sum_{d=1}^{i}f_{i-1,j+d}\times d$

  $=\sum_{d=1}^{i}f_{i-1,j+d}\times (i+j)-\sum_{d=1}^{i}f_{i-1,j+d}\times (j+d)$

  $S2_{i,j}=\sum_{d=0}^{i-1}f_{i-1,j-d}\times i-\sum_{d=0}^{i-1}f_{i-1,j-d}\times d$

  $=\sum_{d=0}^{i-1}f_{i-1,j-d}\times (i-j)+\sum_{d=0}^{i-1}f_{i-1,j-d}\times (j-d)$

  这里的转化比较有意思,将系数化来与枚举的系数相同(如 $j+d,j-d$),便于前缀和优化。

  令 $G1_{i,j}=\sum_{k=-lim}^jf_{i,k},G2_{i,j}=\sum_{k=-lim}^jf_{i,k}\times k$,那么有:

  $S1_{i,j}=(i+j)\times (G1_{i-1,i+j}-G1_{i-1,j})+G2_{i-1,j}-G2_{i-1,j+i}$

  $S2_{i,j}=(i-j)\times (G1_{i-1,j}-G1_{i-1,j-i})+G2_{i-1,j}-G2_{i-1,j-i}$

  至此,我们可以 $O(1)$ 转移方程,总时间复杂度 $O(n^3)$。

  还有一点需要注意的就是 $f_{i,j}$ 中的 $j$ 可以是负数,注意数组下标加上一个定值来储存。代码中用 $M$ 来表示。


 三、完整代码

 1 #include<iostream>
 2 
 3 #define N 510
 4 #define M 130000
 5 #define ll long long
 6 #define rep(i,l,r) for(ll i=l;i<=r;i++)
 7 
 8 using namespace std;
 9 
10 ll n,mod,ans,fac[N],C[N][N];
11 ll f[M<<1],s1[M<<1],s2[M<<1],g1[M<<1],g2[M<<1];
12 
13 void calc(ll x){
14     
15     ll lim=x*(x-1)/2,cnt=0;
16     
17     rep(i,M-lim-x,M+lim+x){
18         g1[i]=(g1[i-1]+f[i])%mod;
19         g2[i]=(g2[i-1]+f[i]*i)%mod;
20     }
21     
22     rep(i,M-lim,M+lim){
23         s1[i]=(x+i)*(g1[i+x]-g1[i])+g2[i]-g2[i+x];
24         s2[i]=(x-i)*(g1[i]-g1[i-x])+g2[i]-g2[i-x];
25     }
26     
27     rep(i,M-lim,M+lim){
28         s1[i]=(s1[i]%mod+mod)%mod;
29         s2[i]=(s2[i]%mod+mod)%mod;
30     }
31     
32     rep(i,M+1,M+lim) (cnt+=s1[i])%=mod;
33     (ans+=C[n][n-x]*fac[n-x]%mod*cnt%mod)%=mod;
34     
35     rep(i,M-lim,M+lim) f[i]=(s1[i]+s2[i])%mod;
36     
37 }
38 
39 signed main(){
40     
41     ios::sync_with_stdio(false);
42     cin.tie(0); cout.tie(0);
43     
44     cin>>n>>mod; fac[0]=f[M]=1;
45     rep(i,1,n) fac[i]=fac[i-1]*i%mod;
46     
47     rep(i,0,n) C[i][0]=1;
48     rep(i,0,n) rep(j,1,i) C[i][j]=(C[i-1][j]+C[i-1][j-1])%mod;
49     
50     rep(i,2,n) calc(i);
51     cout<<ans<<'\n';
52     
53     return 0;
54     
55 }

四、写题心得:

  感觉 $feecle$ 选的题都还挺有趣,拜谢 。

  并且掌握了新的推式子技巧和方法,很高兴。

  忘了说,顺便水了一道蓝题,$CF1542E1$。

标签:G2,G1,题解,rep,times,CF1542E2,pi,sum
From: https://www.cnblogs.com/yhy-trh/p/18004098/CF1542E2

相关文章

  • 230718B3-path 题解
    感谢cn_ryh大佬的怂恿(否则我真不会动这个题感谢cszhpdx的指导帮助qwq(让我们膜拜一下场切的浩杨哥orz解决这个题让人很有成就感(题意给定一个基环树,边有长度l、限速v、价值w(每单位时间)已知起点s、终点t、最高速度u,求最小花费边数、询问次数$10^5$解法首先学习一下基......
  • 基于客户真实使用场景的云剪辑Timeline问题解答与代码实操
    本文为阿里云智能媒体服务IMS「云端智能剪辑」实践指南第6期,从客户真实实践场景出发,分享一些Timeline小技巧(AI_TTS、主轨道、素材对齐),助力客户降低开发时间与成本。欧叔|作者故事的开始要从一条客户的真实反馈说起。  Round1:视频比音频长,怎么办?某天,一位客户加入了智能媒......
  • 盘点那些硬件+项目学习套件:Hi3861鸿蒙开发板及入门常见问题解答
    华清远见20岁了~过去3年里,华清远见研发中心针对个人开发板业务,打造了多款硬件+项目学习套件,涉及STM32单片机、嵌入式、物联网、人工智能、鸿蒙、ESP32、阿里云IoT等多技术方向。今天我们来盘点一下,比较受欢迎几款“硬件+项目”学习套件,以及一些初学者比较关注的问题。盘点二:Hi3861......
  • fatal: couldn't find remote ref master 问题解决!
    这个错误信息通常出现在使用Git命令尝试从远程仓库克隆、拉取(pull)或推送(push)时,指定的分支(在这个案例中是master)在远程仓库中不存在。这种情况可能由以下几个原因导致:1.分支名称错误远程仓库中不存在名为master的分支:随着Git和GitHub的更新,master分支被重新命名为main......
  • AcWing 520. 子串 题解
    ps:觉得这编号很特殊就做了一下题目传送门算法(线性DP,前缀和)\(O(nmk)\)首先考虑如何DP,然后再考虑如何优化。状态表示:f[i,j,k]表示只用S的前i个字母,选取了k段,可以匹配T的前j个字母的方案数。状态计算:将f[i,j,k]表示的所有方案分成两大类:不用S[i],则方案数是f[i-1,......
  • P9309 [EGOI2021] Number of Zeros题解
    模拟赛时以为是进位制的题目,结果还做出来了。此题解解法与其它相似,但观察的角度不同(作者的脑回路不同)。此题问\(a\simb\)的最小公倍数中后导\(0\)的个数,即求其中\(2\)和\(5\)个数的最小值。分别计算即可,想到进位制,以\(a=10\),\(b=12\)时\(2\)的个数为例:1001(9)......
  • P9612 [CERC2019] Light Emitting Hindenburg 题解
    题目传送门题目大意这个题目简化一下就是求\(n\)个数中取\(k\)个数按位与的最大值思路很容易想到贪心。题中说道输入的数在二进制下最多\(29\)位,所以我们从\(29\)开始遍历二进制位,如果当前位有大于等于\(k\)个\(1\),那么标记一下这些数,可以发现剩下的比当前位低的......
  • AcWing 3721. 求30的倍数 题解
    传送门stoi这里我们来了解一个函数\(stoi\)作用是将\(n\)进制的字符串转化为十进制,使用时包含头文件\(string\)定义如下:intstoi(conststd::string&str,std::size_t*pos=nullptr,intbase=10);参数:\(str\)-待转换的字符\(pos\)-其取值可以是一个空字......
  • CF1687D Cute number 题解
    题目链接点击打开链接题目解法一个数\(c\)是可爱(下文称为合法)的,当且仅当\(c\in[x^2,x(x+1)]\)令\(a_i\)属于\([x_i,x_i(x_i+1)]\)一个显然的范围是\(x_1\le2\times10^6\)考虑枚举\(x_1\)现在说明一个结论:\(x_1\)固定时,\(x_i\)也固定了说明:不难发现,合法的不合......
  • CF620E New Year Tree 题解
    题目链接:CF或者洛谷这题很简单,看到颜色数,HH的项链?树,树上的HH的项链?带修,树上的镜中的昆虫?\(c_i\le60\),噢,easy了。考虑一类信息,表示有和无,对于某种颜色来讲,\(0/1\)表示无或者有,而或运算让我们从小区间的有无情况反映到大区间的有无情况。一种暴力的想法,为每种颜色建立一棵有......