最小代价问题
来源:互联网 发布:商业计划书运营数据 编辑:程序博客网 时间:2024/06/07 04:25
Description
设有一个n×m(小于100)的方格(如图所示),在方格中去掉某些点,方格中的数字代表距离(为小于100的数,如果为0表示去掉的点),试找出一条从A(左上角)到B(右下角)的路径,经过的距离和为最小(此时称为最小代价),从A出发的方向只能向右,或者向下。
Sample Input
4 4
4 10 7 0
3 2 2 9
0 7 0 4
11 6 12 1
Sample Output
(1,1)->(2,1)->(2,2)->(2,3)->(2,4)->(3,4)->(4,4)
24
var i,j,n,m:longint; a,k,d:array[-1..101,-1..101]of longint; f:array[-1..101,-1..101]of boolean;procedure print(x,y:longint);begin if (x=1)and(y=1) then begin write('(',x,',',y,')'); exit; end; if d[x,y]=1 then print(x,y-1) else print(x-1,y); write('->(',x,',',y,')');end;begin readln(n,m); for i:=1 to n do for j:=1 to m do begin read(a[i,j]); if a[i,j]>0 then f[i,j]:=true; k[i,j]:=maxlongint div 2; end; for i:=1 to m do if f[1,i] then begin k[1,i]:=k[1,i-1]+a[1,i]; d[1,i]:=1; end; for i:=2 to n do if f[i,1] then begin k[i,1]:=k[i-1,1]+a[i,1]; d[i,1]:=2; end; for i:=2 to n do for j:=2 to m do if f[i,j] then if ((k[i-1,j]+a[i,j])<(k[i,j-1]+a[i,j]))and(f[i-1,j]) then begin d[i,j]:=2; k[i,j]:=k[i-1,j]+a[i,j]; end else if f[i,j-1]then begin d[i,j]:=1; k[i,j]:=k[i,j-1]+a[i,j]; end; print(n,m); writeln; writeln(k[n,m]-a[n,m]);end.
在这题里面,加一个boolean的数组容易做一些。
0 0
- 最小代价问题
- 最小代价问题
- 最小代价问题
- [DP]最小代价问题
- 最小代价问题
- 最小代价问题
- 买一送一的最小代价问题
- SSL 1460——最小代价问题
- 最小代价
- 最小代价;;;;
- 最小代价
- 最小代价
- POJ1251(基础的最小代价生成树问题)
- 动态规划系列问题-最小编辑代价
- 霍夫曼树之切割木板最小总代价问题
- 最小代价子母树
- 最小代价树
- 最小代价树
- OpenCV的cvReleaseImage释放内存出错解决方法及Mat格式与IplImage格式相互转换
- android 6.0 熄屏后导致GPS 位置 监听无法获取
- linux运维学习第十八课
- Java异常处理面试题归纳
- Ubuntu 15.04下apt-get安装JDK
- 最小代价问题
- java java中subString、split、stringTokenizer三种截取字符串方法的性能比较
- Python 异常处理--raise函数用法
- 面试体会---持续更新
- Vue.js 实用技巧(二)
- BaseRecyclerViewAdapterHelper之BaseItemDraggableAdapter实现拖拽功能
- softmax非常形象的示意图
- ajax详解
- 转:nginx+CGI/FASTCGI