mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-09-02 22:13:28 +08:00
update
This commit is contained in:
@@ -12,7 +12,7 @@
|
||||
"translatedContent": "<p>你有一个只支持单个标签页的 <strong>浏览器</strong> ,最开始你浏览的网页是 <code>homepage</code> ,你可以访问其他的网站 <code>url</code> ,也可以在浏览历史中后退 <code>steps</code> 步或前进 <code>steps</code> 步。</p>\n\n<p>请你实现 <code>BrowserHistory</code> 类:</p>\n\n<ul>\n\t<li><code>BrowserHistory(string homepage)</code> ,用 <code>homepage</code> 初始化浏览器类。</li>\n\t<li><code>void visit(string url)</code> 从当前页跳转访问 <code>url</code> 对应的页面 。执行此操作会把浏览历史前进的记录全部删除。</li>\n\t<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>\n\t<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>\n</ul>\n\n<p> </p>\n\n<p><strong>示例:</strong></p>\n\n<pre><strong>输入:</strong>\n["BrowserHistory","visit","visit","visit","back","back","forward","visit","forward","back","back"]\n[["leetcode.com"],["google.com"],["facebook.com"],["youtube.com"],[1],[1],[1],["linkedin.com"],[2],[2],[7]]\n<strong>输出:</strong>\n[null,null,null,null,"facebook.com","google.com","facebook.com",null,"linkedin.com","google.com","leetcode.com"]\n\n<strong>解释:</strong>\nBrowserHistory browserHistory = new BrowserHistory("leetcode.com");\nbrowserHistory.visit("google.com"); // 你原本在浏览 "leetcode.com" 。访问 "google.com"\nbrowserHistory.visit("facebook.com"); // 你原本在浏览 "google.com" 。访问 "facebook.com"\nbrowserHistory.visit("youtube.com"); // 你原本在浏览 "facebook.com" 。访问 "youtube.com"\nbrowserHistory.back(1); // 你原本在浏览 "youtube.com" ,后退到 "facebook.com" 并返回 "facebook.com"\nbrowserHistory.back(1); // 你原本在浏览 "facebook.com" ,后退到 "google.com" 并返回 "google.com"\nbrowserHistory.forward(1); // 你原本在浏览 "google.com" ,前进到 "facebook.com" 并返回 "facebook.com"\nbrowserHistory.visit("linkedin.com"); // 你原本在浏览 "facebook.com" 。 访问 "linkedin.com"\nbrowserHistory.forward(2); // 你原本在浏览 "linkedin.com" ,你无法前进任何步数。\nbrowserHistory.back(2); // 你原本在浏览 "linkedin.com" ,后退两步依次先到 "facebook.com" ,然后到 "google.com" ,并返回 "google.com"\nbrowserHistory.back(7); // 你原本在浏览 "google.com", 你只能后退一步到 "leetcode.com" ,并返回 "leetcode.com"\n</pre>\n\n<p> </p>\n\n<p><strong>提示:</strong></p>\n\n<ul>\n\t<li><code>1 <= homepage.length <= 20</code></li>\n\t<li><code>1 <= url.length <= 20</code></li>\n\t<li><code>1 <= steps <= 100</code></li>\n\t<li><code>homepage</code> 和 <code>url</code> 都只包含 '.' 或者小写英文字母。</li>\n\t<li>最多调用 <code>5000</code> 次 <code>visit</code>, <code>back</code> 和 <code>forward</code> 函数。</li>\n</ul>\n",
|
||||
"isPaidOnly": false,
|
||||
"difficulty": "Medium",
|
||||
"likes": 45,
|
||||
"likes": 47,
|
||||
"dislikes": 0,
|
||||
"isLiked": null,
|
||||
"similarQuestions": "[]",
|
||||
@@ -167,7 +167,7 @@
|
||||
"__typename": "CodeSnippetNode"
|
||||
}
|
||||
],
|
||||
"stats": "{\"totalAccepted\": \"10.6K\", \"totalSubmission\": \"17.2K\", \"totalAcceptedRaw\": 10648, \"totalSubmissionRaw\": 17215, \"acRate\": \"61.9%\"}",
|
||||
"stats": "{\"totalAccepted\": \"11.1K\", \"totalSubmission\": \"17.9K\", \"totalAcceptedRaw\": 11082, \"totalSubmissionRaw\": 17929, \"acRate\": \"61.8%\"}",
|
||||
"hints": [
|
||||
"Use two stack one for back history and one for forward history and simulate the functions.",
|
||||
"Can you do faster by using different data structure ?"
|
||||
|
Reference in New Issue
Block a user