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=nextvisit[i]: 第一次到i之后回退到的位置 to=nextvisit[i]:第一次到i之后回退到的位置
f [ i ] : 从奇数次到 i 到奇数次到 i + 1 所需要的天数 f[i]: 从奇数次到 i 到奇数次到i+1所需要的天数 f[i]:从奇数次到i到奇数次到i+1所需要的天数
d p [ i ] : 从 0 号房间出发到 i + 1 号房间所需要的天数 dp[i]: 从0号房间出发到i+1号房间所需要的天数 dp[i]:从0号房间出发到i+1号房间所需要的天数

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

  1. (奇数次到 i i i)从起点走到 i i i; T = d p [ i − 1 ] T=dp[i-1] T=dp[i−1]
  2. 从 i i i跳到 n e x t V i s i t [ i ] nextVisit[i] nextVisit[i]; T = 1 T=1 T=1
  3. 从 n e x t V i s i t [ i − 1 ] nextVisit[i-1] nextVisit[i−1]再走到 i i i; T = d p [ i − 1 ] − d p [ n e x t v i s i t [ i − 1 ] ] T=dp[i-1]-dp[nextvisit[i-1]] T=dp[i−1]−dp[nextvisit[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 dp[i]=dp[i-1] + 1 + dp[i-1]-dp[nextvisit[i-1]] + 1 dp[i]=dp[i−1]+1+dp[i−1]−dp[nextvisit[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开始。
    }
};

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

相关推荐
索迪迈科技1 小时前
Flink Task线程处理模型:Mailbox
java·大数据·开发语言·数据结构·算法·flink
元亓亓亓2 小时前
LeetCode热题100--230. 二叉搜索树中第 K 小的元素--中等
算法·leetcode·职场和发展
草莓熊Lotso2 小时前
《算法闯关指南:优选算法-双指针》--01移动零,02复写零
c语言·c++·经验分享·算法·leetcode
焜昱错眩..3 小时前
代码随想录算法训练营第三十九天|62.不同路径 63.不同路径ll
算法
ajassi20006 小时前
开源 C++ QT Widget 开发(十五)多媒体--音频播放
linux·c++·qt·开源
焦耳加热7 小时前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn7 小时前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6067 小时前
常用排序算法核心知识点梳理
算法·排序
鹅毛在路上了8 小时前
C++, ffmpeg, libavcodec-RTSP拉流,opencv实时预览
c++·opencv·ffmpeg
John_ToDebug9 小时前
定制 ResourceBundle 的实现与 DuiLib 思想在 Chromium 架构下的应用解析
c++·chrome·ui