递归和递推解决机器人走方格问题

走方格的问题,一个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];//最后的即是我们所要求解的答案
	}
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值