1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-26 02:00:27 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode-cn/problem (Chinese)/访问完所有房间的第一天 [first-day-where-you-have-been-in-all-the-rooms].html

57 lines
2.6 KiB
HTML
Raw Normal View History

2022-03-27 20:38:29 +08:00
<p>你需要访问&nbsp;<code>n</code> 个房间,房间从 <code>0</code><code>n - 1</code> 编号。同时,每一天都有一个日期编号,从 <code>0</code> 开始,依天数递增。你每天都会访问一个房间。</p>
<p>最开始的第 <code>0</code> 天,你访问&nbsp;<code>0</code> 号房间。给你一个长度为 <code>n</code><strong>下标从 0 开始</strong> 的数组 <code>nextVisit</code> 。在接下来的几天中,你访问房间的 <strong>次序</strong> 将根据下面的 <strong>规则</strong> 决定:</p>
<ul>
<li>假设某一天,你访问&nbsp;<code>i</code> 号房间。</li>
<li>如果算上本次访问,访问&nbsp;<code>i</code> 号房间的次数为 <strong>奇数</strong> ,那么 <strong>第二天</strong> 需要访问&nbsp;<code>nextVisit[i]</code> 所指定的房间,其中 <code>0 &lt;= nextVisit[i] &lt;= i</code></li>
<li>如果算上本次访问,访问&nbsp;<code>i</code> 号房间的次数为 <strong>偶数</strong> ,那么 <strong>第二天</strong> 需要访问&nbsp;<code>(i + 1) mod n</code> 号房间。</li>
</ul>
<p>请返回你访问完所有房间的第一天的日期编号。题目数据保证总是存在这样的一天。由于答案可能很大,返回对 <code>10<sup>9</sup> + 7</code> 取余后的结果。</p>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<pre>
<strong>输入:</strong>nextVisit = [0,0]
<strong>输出:</strong>2
<strong>解释:</strong>
- 第 0 天,你访问房间 0 。访问 0 号房间的总次数为 1 ,次数为奇数。
&nbsp; 下一天你需要访问房间的编号是 nextVisit[0] = 0
- 第 1 天,你访问房间 0 。访问 0 号房间的总次数为 2 ,次数为偶数。
&nbsp; 下一天你需要访问房间的编号是 (0 + 1) mod 2 = 1
- 第 2 天,你访问房间 1 。这是你第一次完成访问所有房间的那天。
</pre>
<p><strong>示例 2</strong></p>
<pre>
<strong>输入:</strong>nextVisit = [0,0,2]
<strong>输出:</strong>6
<strong>解释:</strong>
你每天访问房间的次序是 [0,0,1,0,0,1,2,...] 。
第 6 天是你访问完所有房间的第一天。
</pre>
<p><strong>示例 3</strong></p>
<pre>
<strong>输入:</strong>nextVisit = [0,1,2,0]
<strong>输出:</strong>6
<strong>解释:</strong>
你每天访问房间的次序是 [0,0,1,1,2,2,3,...] 。
第 6 天是你访问完所有房间的第一天。
</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>n == nextVisit.length</code></li>
<li><code>2 &lt;= n &lt;= 10<sup>5</sup></code></li>
<li><code>0 &lt;= nextVisit[i] &lt;= i</code></li>
</ul>