洛谷 我讲的应该没有这个[https://www.luogu.org/blog/user55639/solution-p2467]清楚. 贴个代码算了: #include <bits/stdc++.h> using namespace std; int n,p,f[2][5000]; int main() { cin>>n>>p; bool t=0; f[t][1]=1; for (int i=2;i<=n;++i) { t=!t; for (int j=1;j&…
同波浪,简单dp. 高度从1到n插入山脉,设f[i][j][k]表示插入了i个山脉,组成了j段,边界上有k个山脉的方案数. 那么新插入的山脉只会:插入在边界上且自己是一段.插入在边界上且与最左边的段相连.不在边界上且自己是一段.不在边界上且连接两段. 大力讨论即可 // luogu-judger-enable-o2 #include<bits/stdc++.h> #define il inline #define vd void typedef long long ll; il int gi(…