链接
来源:牛客网
[编程题]机器人走方格I
有一个XxY的网格,一个机器人只能走格点且只能向右或向下走,要从左上角走到右下角。请设计一个算法,计算机器人有多少种走法。
给定两个正整数int x,int y,请返回机器人的走法数目。保证x+y小于等于12。
测试样例:
2,2
返回:2
思路:
每一步都只能往下或者左走,所以每一步都只有两个方法,所以用递归很方便,而且题目上约束x+y<=12,不必担心递归的深度。
递归的结束条件,就是当他走的只剩一行或一列时就只有一种方法可走,此时返回1,其余的时候不是往下走,就是往左走,因此递归(x-1,y)和(x,y-1)就可以。
代码:
import java.util.*;
public class Robot {
public int countWays(int x, int y) {
if(x==1||y==1){
return 1;
}
return countWays(x-1,y)+countWays(x,y-1);
}
}