第一个问题可以用贪心+二分解决第二个问题用f[i][j]表示i次分割后分割到j且满足条件的方案数,$f[i][j]=\sum_{k<j且sum[j]-sum[k]<=ans}f[i-1][k]$优化时间:前缀和优化,二分要先预处理出来(也可以用优先队列)优化空间:发现f并没有什么用处,只需要记录前缀和数组,再对其滚动即可 1 #include<bits/stdc++.h> 2 using namespace std; 3 #define mod 10007 4 int n,m,an…
[BZOJ1044][HAOI2008]木棍分割(动态规划,贪心) 题面 BZOJ 洛谷 题解 第一问随便二分一下就好了,贪心\(check\)正确性显然. 第二问随便前缀和+单调队列优化一下\(dp\)就完了. #include<iostream> #include<cstdio> using namespace std; #define MAX 50500 #define MOD 10007 void add(short int &x,short int y){x+=y…