576. 出界的路径数

576. 出界的路径数

LeetCode
576. 出界的路径数

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

思路

暴力递归肯定是不能的,都要对1e9 + 7取模了,暴力肯定超时,但是又确确实实是递归问题,考虑优化
记忆化递归
利用re数组记录下来曾经走过的路,当下一次遍历到这个点的时候,利用以前得到的数据,直接相加,不再继续遍历

class Solution {
public:
    typedef long long ll;
    const int MOD = 1e9 + 7;
    ll re[52][52][52];

    int find(int x, int y, int dep, int n, int m) {
        if(x <= 0 || x > m || y <= 0 || y > n){
            return 1;
        }
        if(!dep) return 0;
        if(re[x - 1][y][dep - 1] == -1) re[x - 1][y][dep - 1] = find(x - 1, y, dep - 1, n, m);
        if(re[x + 1][y][dep - 1] == -1) re[x + 1][y][dep - 1] = find(x + 1, y, dep - 1, n, m);
        if(re[x][y - 1][dep - 1] == -1) re[x][y - 1][dep - 1] = find(x, y - 1, dep - 1, n, m);
        if(re[x][y + 1][dep - 1] == -1) re[x][y + 1][dep - 1] = find(x, y + 1, dep - 1, n, m);
        re[x][y][dep] = (re[x - 1][y][dep - 1] + re[x + 1][y][dep - 1] + re[x][y - 1][dep - 1] + re[x][y + 1][dep - 1]) % MOD;
        return re[x][y][dep];
    }

    int findPaths(int m, int n, int maxMove, int startRow, int startColumn) {
        memset(re, -1, sizeof re);
        return find(startRow + 1, startColumn + 1,  maxMove, n, m);//防止边界特判,坐标都加一
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Miss .

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值