Leetcode-1997-访问完所有房间的第一天-c++

题目详见https://leetcode.cn/problems/first-day-where-you-have-been-in-all-the-rooms/

t o = n e x t v i s i t i : 第一次到 i 之后回退到的位置 to=nextvisiti: 第一次到i之后回退到的位置 to=nextvisiti:第一次到i之后回退到的位置
f i : 从奇数次到 i 到奇数次到 i + 1 所需要的天数 fi: 从奇数次到 i 到奇数次到i+1所需要的天数 fi:从奇数次到i到奇数次到i+1所需要的天数
d p i : 从 0 号房间出发到 i + 1 号房间所需要的天数 dpi: 从0号房间出发到i+1号房间所需要的天数 dpi:从0号房间出发到i+1号房间所需要的天数

首次到第i+1个房间 d p i dpi dpi分4步:

  1. (奇数次到 i i i)从起点走到 i i i; T = d p i − 1 T=dpi-1 T=dpi−1
  2. 从 i i i跳到 n e x t V i s i t i nextVisiti nextVisiti; T = 1 T=1 T=1
  3. 从 n e x t V i s i t i − 1 nextVisiti-1 nextVisiti−1再走到 i i i; T = d p i − 1 − d p n e x t v i s i t \[ i − 1 ] T=dpi-1-dpnextvisit\[i-1] T=dpi−1−dpnextvisit\[i−1]
  4. (偶数次到 i i i)从 i i i走到 i + 1 i+1 i+1; T = 1 T=1 T=1

综上
d p i = d p i − 1 + 1 + d p i − 1 − d p n e x t v i s i t \[ i − 1 ] + 1 dpi=dpi-1 + 1 + dpi-1-dpnextvisit\[i-1] + 1 dpi=dpi−1+1+dpi−1−dpnextvisit\[i−1]+1

对你没看错是题解错了

注释代码

cpp 复制代码
class Solution {
public:
    int firstDayBeenInAllRooms(vector<int>& nextVisit) {
        int mod = 1e9 + 7;
        int len = nextVisit.size();
        vector<int> dp(len);

        dp[0] = 2; //初始化原地待一天 + 访问下一个房间一天(第二步的时间)
        for (int i = 1; i < len; i++) {
            int to = nextVisit[i];
            dp[i] = 2 + dp[i - 1];	//1,2,4步
            
            if (to != 0) {
            	// 这里是第三步的第一部分,我做的时候主要这里这个dp[to - 1]比较难理解
            	// dp[to] 代表的是从0到to+1,所以想到to的话就是dp[to - 1]
                dp[i] = (dp[i] - dp[to - 1] + mod) % mod; //避免负数
            }
            dp[i] = (dp[i] + dp[i - 1]) % mod; // 这里是第三步的第二部分
        }
        return dp[len - 2]; //输出dp[n-2], 也就是到n-1的距离,而此时恰好下标从0开始。
    }
};

笔者也在新手学习期中,所写的内容主要与大家交流学习使用,如有发现任何问题敬请指正!

相关推荐
小雨下雨的雨2 小时前
井字棋AI机器人实现详解 - Minimax算法实战-鸿蒙PC Electron框架完成
前端·人工智能·算法·华为·electron·鸿蒙
xieliyu.5 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
一条小锦吕*5 小时前
基于Spring Boot + 数据可视化 + 协同过滤算法的推荐系统设计与实现(源码+论文+部署全讲解)
spring boot·算法·信息可视化
如竟没有火炬7 小时前
最大矩阵——单调栈
数据结构·python·线性代数·算法·leetcode·矩阵
8Qi87 小时前
LeetCode 1143 & 718:最长公共子序列 / 最长重复子数组
算法·leetcode·职场和发展·动态规划
绿算技术8 小时前
万卡推理集群存储选型分析:从核心架构到应用视角
大数据·科技·算法·架构
Qt程序员8 小时前
Linux RCU 原理与应用
linux·c++·内核·linux内核·rcu
想吃火锅10059 小时前
【leetcode】1.两数之和js版
javascript·算法·leetcode
qeen879 小时前
【C++】类与对象之类的默认成员函数(二)
android·c语言·开发语言·c++·笔记·学习