http://acm.hdu.edu.cn/showproblem.php?pid=4362
题意:有m个阶段,每个阶段都有n个龙珠,当在某一阶段选择一个龙珠,该阶段其他龙珠都会消失。给出两个m*n的矩阵,第一个矩阵表示消灭第i个阶段第j个龙珠的位置,第二个矩阵表示取第i个阶段第j个龙珠消耗的能量,同时当第x个位置到第个位置需要消耗 | y - x|的能量。问最后每个阶段取走一个龙珠最小的能量消耗。
思路:状态转移方程很容易,dp[i][j] = min(dp[i-1][k] + abs( pos[i-1][k] - pos[i][j] ) ) + energy[i][j]。
但由于n较大,想着会TLE。试着敲出来,果真TLE。改了改细节,然后加了个内联函数水过。
#include <stdio.h> #include <string.h> #include <algorithm> #include <cmath> using namespace std; const int INF = 0x3f3f3f3f; int n,m,x; int pos[55][1010],ener[55][1010],dp[55][1010]; inline int chk(int x) { if(x < 0) return -x; return x; } int main() { int test; scanf("%d",&test); while(test--) { scanf("%d %d %d",&n,&m,&x); for(int i = 0; i < n; i++) { for(int j = 0; j < m; j++) scanf("%d",&pos[i][j]); } for(int i = 0; i < n; i++) { for(int j = 0; j < m; j++) scanf("%d",&ener[i][j]); } for(int j = 0; j < m; j++) dp[0][j] = chk(pos[0][j]-x) + ener[0][j]; for(int i = 1; i < n; i++) { for(int j = 0; j < m; j++) { int tmp = INF; for(int k = 0; k < m; k++) { int sum = dp[i-1][k] + chk(pos[i-1][k] - pos[i][j]); if(tmp > sum) tmp = sum; } dp[i][j] = tmp+ener[i][j]; } } int ans = INF; for(int j = 0; j < m; j++) ans = min(ans, dp[n-1][j]); printf("%d\n",ans); } return 0; }
hdu Dragon Ball(dp),布布扣,bubuko.com
原文:http://blog.csdn.net/u013081425/article/details/20958055