码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • [记忆化dfs]leetcode2400:恰好移动 k 步到达某一位置的方法数目(medium)


    题目:
    在这里插入图片描述


    题解:

    思路:记忆化 dfs

    • 状态定义参考 1575. 统计所有可行路径,本题为该题的简化版本,状态转移的计算量只有 2 个。
    • 状态f[pos][rest]=c:表示在当前位置 pos 上,还能走 rest 步,走到终点 end 的总路径步数为 c 条。
    • 状态转移:向前走一步或者向后走一步,这两种情况进行枚举即可。

    代码如下:

    const int mod = 1e9+7, N = 1010;
    using PII = pair<int,int>;
    class Solution {
    public:
        // 记忆化 dfs
        // 时间复杂度为 O(n*k*2),状态的数量为 O(n*k),对于每个状态的转移需要 O(2)的时间复杂度
        // 空间复杂度为 O(n*k),为状态的数量
        // f[pos][rest]=c 表示在当前位置 pos 上,还能走 rest 步,走到终点 end 的总路径步数为 c 条。
        map<PII,int> f;
        int numberOfWays(int pos, int end, int rest) {
            // 无法直接从位置 pos 到达终点 end,那么间接也是无法从位置 pos 走到终点 end 的,所以直接返回 0
            if(abs(pos-end)>rest)return 0;
            // 由于 abs(pos-end)>=0,因此 abs(pos-end)>=rest>=0
            if(rest==0)return pos==end;
            // 当前的状态
            PII cur={pos,rest};
            // 当前状态已经被计算过了,直接返回计算过的状态值
            if(f.count(cur))return f[cur];
            // 进行状态转移:枚举两种转移方式,向前走一步或者向后走一步
            return f[cur]=(numberOfWays(pos-1,end,rest-1)+numberOfWays(pos+1,end,rest-1))%mod;
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
  • 相关阅读:
    linux 3.13版本nvme驱动阅读记录三
    java 上机练习题
    【POJ No. 2352】数星星 Stars
    小红书KOL推广应该注意什么?
    Acwing算法心得——猜测短跑队员的速度(重写比较器)
    Python&C++相互混合调用编程全面实战-24QT按钮事件的Open槽函数中调用python函数
    JAVA茶叶销售网站计算机毕业设计Mybatis+系统+数据库+调试部署
    用边缘计算网关解决离散行业数采问题-天拓四方
    MR混合现实情景实训教学系统模拟高空作业情景实训教学
    python 网络爬虫全流程教学,从入门到实战(requests+bs4+存储文件)
  • 原文地址:https://blog.csdn.net/qq_43152052/article/details/126904686
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号