Educational Codeforces Round 80 Editorial 解题报告

SS有点不稳定一直进不去cf,进去的时候已经过了不少时间了,然后人就比较着急,反而做的更慢了。

A题数学题 很简单

B题数学题 很简单

C题我看出来是一道dp题了,也看出来这道题可以用数学方法直接推公式了。
然而我没推出dp递推公式,也没推出数学公式。
这道题需要简单转换一下,然后才能做,这里我没想到这一点,题目做的不够多吧。
题意是[1,n]范围中任取构成数列An和数列Bn,满足An为非降序列,Bn为非升序列,且Ai>=Bi。
由题意易推出Am>=Ai,Bm<=Bi;又由Am>=Bm可使Bn逆序连接An构造一个长度为2m的非降序列Cn;

解法1(排列组合):
然后再有高中知识排列组合转换为求C(n+2m-1,2m)的问题,然后套公式就出来了,看官方题解用的python短短几行就实现了大数的计算,有空自己也要去学一下python,偶尔用一下做有关计算的问题应该挺爽的。

python用排列组合算应该是自带高精度可以直接做的,但是C++做起来很麻烦。
1.nCrModp:
https://www.geeksforgeeks.org/compute-ncr-p-set-1-introduction-and-dynamic-programming-solution/amp/
数据过大会TLE

int nCrModp(int n,int r,int p){
	int C[r+1];
	memset(C,0,sizeof(C));
	C[0]=1;
	for(int i=1;i<=n;i++){
		for(int j=min(i,r);j>0;j--){
			C[j]=(C[j]+C[j-1])%p;
		}
	}
	return C[r];
}

2.Lucas定理(√)

Educational Codeforces Round 80 Editorial 解题报告_第1张图片
解法2(dp):
推递推式f[i][j]=f[i-1][j]+f[i][j-1];//dp[i][j]表示第i位置放数字j的方案数,在i位置放j-1情况时必然i-1位置也能放j;
如果写f[i][j]=f[i-1][j]+f[i][j+1];内层for循环就要j就要逆序遍历由n到1,这样的意义是将非降序列看做看非升序列,两者本质就是掉个头看,也能算出正确答案。
当然别忘了要%mod。

第一次打cf加分,虽然只加了12,不过还是有进步的或许?

你可能感兴趣的:(Educational Codeforces Round 80 Editorial 解题报告)