硬币收集问题
问题描述:
在一个mxn的矩阵中A,每个举证单元存放着一定数量(A(i,j)>=0)的硬币,假设有一个小机器人,它从举证的左上角A(0,0)开始,每经过一个单元格就收集其中的所有硬币,并且只能向右走或者往下走,问它从左上角一直到右下角A(m,n),能够收集最多的硬币是多少?
例如,以2x3的简单矩阵为例:
小机器人如果按照路径:(0,0)->(0,1)->(1,1)->(1,2)的路径走的话,可以收集到最多的硬币数:21。
分析:
由于该问题对每一步所走路径的方向有确定的限制:只能是向右走或者是向下走,实际上寻找其递推式是很简单的。
实现:
package agdp; public class CollectionCoins { private static int[][] initData(int m,int n){ int[][] ary = new int[m][n]; for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { ary[i][j] = (int)(Math.random()*10);//随机生成[0,10]的整数 } } return ary; } public static int getMostCoins(int[][] ary){ int m = ary.length,n = ary[0].length; int[][] aux = new int[m+1][n+1];//aux第0行和第0列均置0,充当哨兵作用 for (int i = 1; i < m+1; i++) { for (int j = 1; j < n+1; j++) { //递推式 aux[i][j] = Math.max(aux[i-1][j], aux[i][j-1])+ary[i-1][j-1]; } } return aux[m][n]; } public static void main(String[] args) { // TODO Auto-generated method stub int m = 3,n = 4; int[][] ary = initData(m,n); // for (int i = 0; i < m; i++) { // for (int j = 0; j < n; j++) { // System.out.print(ary[i][j]+"-"); // } // System.out.println(); // } int result = getMostCoins(ary); System.out.print(result); } }