poj3926】的更多相关文章

题意:有n行路,每行路被分成m段,每一段有长度和权值,要求从最下面一行走到最上面一行某个位置,可以从相邻两行的同一列交点往上走,并且在同一行走的长度要<=K,求走过的最大权值 设f[i][j]为到第i行,第j个交点的最大值设sumvalue[i][j,k]为第i行从第j个交点到第k个交点经过道路的权值之和设sumtime[i][j,k]为第i行从第j个交点到第k个交点经过道路的长度之和则f[i][j]=max{ f[i-1][k]+sumvalue[i][k,j] ,k<=j且sumtime[…
dp+优化 很明显可以用单调队列优化. 记录下自己犯的sb错误:  数组开小,sum没搞清... #include<cstdio> #include<cstring> using namespace std; , M = ; int n, m, k, ans; int q[M]; int dp[N][M], sum[N][M], dis[N][M]; inline int max(int x, int y) { return x > y ? x : y; } inline i…