mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-25 17:50:26 +08:00
47 lines
4.2 KiB
HTML
47 lines
4.2 KiB
HTML
<p>你有一个只支持单个标签页的 <strong>浏览器</strong> ,最开始你浏览的网页是 <code>homepage</code> ,你可以访问其他的网站 <code>url</code> ,也可以在浏览历史中后退 <code>steps</code> 步或前进 <code>steps</code> 步。</p>
|
||
|
||
<p>请你实现 <code>BrowserHistory</code> 类:</p>
|
||
|
||
<ul>
|
||
<li><code>BrowserHistory(string homepage)</code> ,用 <code>homepage</code> 初始化浏览器类。</li>
|
||
<li><code>void visit(string url)</code> 从当前页跳转访问 <code>url</code> 对应的页面 。执行此操作会把浏览历史前进的记录全部删除。</li>
|
||
<li><code>string back(int steps)</code> 在浏览历史中后退 <code>steps</code> 步。如果你只能在浏览历史中后退至多 <code>x</code> 步且 <code>steps > x</code> ,那么你只后退 <code>x</code> 步。请返回后退 <strong>至多</strong> <code>steps</code> 步以后的 <code>url</code> 。</li>
|
||
<li><code>string forward(int steps)</code> 在浏览历史中前进 <code>steps</code> 步。如果你只能在浏览历史中前进至多 <code>x</code> 步且 <code>steps > x</code> ,那么你只前进 <code>x</code> 步。请返回前进 <strong>至多</strong> <code>steps</code>步以后的 <code>url</code> 。</li>
|
||
</ul>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>示例:</strong></p>
|
||
|
||
<pre><strong>输入:</strong>
|
||
["BrowserHistory","visit","visit","visit","back","back","forward","visit","forward","back","back"]
|
||
[["leetcode.com"],["google.com"],["facebook.com"],["youtube.com"],[1],[1],[1],["linkedin.com"],[2],[2],[7]]
|
||
<strong>输出:</strong>
|
||
[null,null,null,null,"facebook.com","google.com","facebook.com",null,"linkedin.com","google.com","leetcode.com"]
|
||
|
||
<strong>解释:</strong>
|
||
BrowserHistory browserHistory = new BrowserHistory("leetcode.com");
|
||
browserHistory.visit("google.com"); // 你原本在浏览 "leetcode.com" 。访问 "google.com"
|
||
browserHistory.visit("facebook.com"); // 你原本在浏览 "google.com" 。访问 "facebook.com"
|
||
browserHistory.visit("youtube.com"); // 你原本在浏览 "facebook.com" 。访问 "youtube.com"
|
||
browserHistory.back(1); // 你原本在浏览 "youtube.com" ,后退到 "facebook.com" 并返回 "facebook.com"
|
||
browserHistory.back(1); // 你原本在浏览 "facebook.com" ,后退到 "google.com" 并返回 "google.com"
|
||
browserHistory.forward(1); // 你原本在浏览 "google.com" ,前进到 "facebook.com" 并返回 "facebook.com"
|
||
browserHistory.visit("linkedin.com"); // 你原本在浏览 "facebook.com" 。 访问 "linkedin.com"
|
||
browserHistory.forward(2); // 你原本在浏览 "linkedin.com" ,你无法前进任何步数。
|
||
browserHistory.back(2); // 你原本在浏览 "linkedin.com" ,后退两步依次先到 "facebook.com" ,然后到 "google.com" ,并返回 "google.com"
|
||
browserHistory.back(7); // 你原本在浏览 "google.com", 你只能后退一步到 "leetcode.com" ,并返回 "leetcode.com"
|
||
</pre>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>提示:</strong></p>
|
||
|
||
<ul>
|
||
<li><code>1 <= homepage.length <= 20</code></li>
|
||
<li><code>1 <= url.length <= 20</code></li>
|
||
<li><code>1 <= steps <= 100</code></li>
|
||
<li><code>homepage</code> 和 <code>url</code> 都只包含 '.' 或者小写英文字母。</li>
|
||
<li>最多调用 <code>5000</code> 次 <code>visit</code>, <code>back</code> 和 <code>forward</code> 函数。</li>
|
||
</ul>
|