走方格的问题,一个mn的方格,从左上角走到左下角,问有多少种走法*
我们可以从m * n为1 * 1 ,1 * 2, 2 * 1,2 * 2然后慢慢开始发现了m * n与m*(n-1)和(m-1)*n有关,并且是它们之和,那么根据这一规律可以直接列出递归的解法:
//递归解决,时间复杂度2的n次方
static int check(int x, int y) {
if(x==1 || y==1) return 1;
return check(x-1,y)+check(x,y-1);
}
递归的复杂度是2^n,当数值超过一定后就很慢,因此我们可以改进一下,用二维数组来记录对应的走法,利用递推关系来求解,显然,第一行和第一列都是为1,然后发现规律,用递推公式arr[i][j]=arr[i-1][j]+arr[i][j-1],然后逐渐求解剩下的,将一个数组填满,最后的就是要求解的答案,代码如下:
//递推解决,时间复杂度n2
//类似于这种从起点到终点只能往下或往右走的,可以用递推公式arr[i][j]=arr[i-1][j]+arr[i][j-1]
static int check1(int m, int n) {
int[][] arr = new int[m+1][n+1];//将数组初始化稍大一点,我们从下标1开始存储。
for(int i=1;i<=m;i++) {//初始化第一列
arr[i][1]=1;
}
for(int i=1;i<=n;i++) {//初始化第一行
arr[1][i]=1;
}
for(int i=2;i<=m;i++) {
for(int j=2;j<=n;j++) {
arr[i][j]=arr[i-1][j]+arr[i][j-1];
}
}
return arr[m][n];//最后的即是我们所要求解的答案
}