当前位置: 首页 > news >正文

jq网站模板企业推广哪个平台好

jq网站模板,企业推广哪个平台好,凌风wordpress,做网站后期要收维护费吗【LetMeFly】1472.设计浏览器历史记录:一个数组完成模拟,单次操作均O(1) 力扣题目链接:https://leetcode.cn/problems/design-browser-history/ 你有一个只支持单个标签页的 浏览器 ,最开始你浏览的网页是 homepage &#xff0c…

【LetMeFly】1472.设计浏览器历史记录:一个数组完成模拟,单次操作均O(1)

力扣题目链接:https://leetcode.cn/problems/design-browser-history/

你有一个只支持单个标签页的 浏览器 ,最开始你浏览的网页是 homepage ,你可以访问其他的网站 url ,也可以在浏览历史中后退 steps 步或前进 steps 步。

请你实现 BrowserHistory 类:

  • BrowserHistory(string homepage) ,用 homepage 初始化浏览器类。
  • void visit(string url) 从当前页跳转访问 url 对应的页面  。执行此操作会把浏览历史前进的记录全部删除。
  • string back(int steps) 在浏览历史中后退 steps 步。如果你只能在浏览历史中后退至多 x 步且 steps > x ,那么你只后退 x 步。请返回后退 至多 steps 步以后的 url 。
  • string forward(int steps) 在浏览历史中前进 steps 步。如果你只能在浏览历史中前进至多 x 步且 steps > x ,那么你只前进 x 步。请返回前进 至多 steps步以后的 url 。

 

示例:

输入:
["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]]
输出:
[null,null,null,null,"facebook.com","google.com","facebook.com",null,"linkedin.com","google.com","leetcode.com"]解释:
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"

 

提示:

  • 1 <= homepage.length <= 20
  • 1 <= url.length <= 20
  • 1 <= steps <= 100
  • homepage 和 url 都只包含 '.' 或者小写英文字母。
  • 最多调用 5000 次 visit, back 和 forward 函数。

解题方法:数组模拟

使用一个大小可变的数组模拟浏览器(标签页)历史记录。初始值只有一个元素homepage

使用now变量记录当前页面的下标,使用right记录最后一个页面的下标。

同时做到:历史记录数组只增不减,要减小就左移right指针。这样能避免一些重复开辟和释放空间带来的性能损耗。

visit:

  1. now++

    如果now超过了历史记录数组的大小,则将当前页面push到历史记录数组中

    否则,直接将history[now]记为当前页面

  2. right = now。这是因为一旦访问新页面,则无法再“forward”

    并不需要真的将“无法forward到的页面”从数组中移除,直接等待新访问页面将其覆盖即可

back:

now = max(0, now - step),然后直接返回history[now]

forward:

now = min(right, now + step),然后直接返回history[now]

  • 时间复杂度 O ( N 2 ) O(N^2) O(N2)
  • 空间复杂度 O ( N log ⁡ N ) O(N\log N) O(NlogN)

AC代码

C++
/** @Author: LetMeFly* @Date: 2025-02-26 13:16:28* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-02-26 13:37:36*/
class BrowserHistory {
private:vector<string> history;int now, right;
public:BrowserHistory(string homepage) {history.push_back(homepage);now = right = 0;}void visit(string url) {if (++now == history.size()) {history.push_back(url);} else {history[now] = url;}right = now;}string back(int steps) {now = max(0, now - steps);return history[now];}string forward(int steps) {now = min(right, now + steps);return history[now];}
};/*** Your BrowserHistory object will be instantiated and called as such:* BrowserHistory* obj = new BrowserHistory(homepage);* obj->visit(url);* string param_2 = obj->back(steps);* string param_3 = obj->forward(steps);*/
  • 执行用时分布14ms击败92.71%
  • 消耗内存分布60.61MB击败96.09%
Python
'''
Author: LetMeFly
Date: 2025-02-26 13:38:49
LastEditors: LetMeFly.xyz
LastEditTime: 2025-02-26 13:41:11
'''
class BrowserHistory:def __init__(self, homepage: str):self.history = [homepage]self.now = self.right = 0def visit(self, url: str) -> None:self.now += 1if self.now == len(self.history):self.history.append(url)else:self.history[self.now] = urlself.right = self.nowdef back(self, steps: int) -> str:self.now = max(0, self.now - steps)return self.history[self.now]def forward(self, steps: int) -> str:self.now = min(self.right, self.now + steps)return self.history[self.now]# Your BrowserHistory object will be instantiated and called as such:
# obj = BrowserHistory(homepage)
# obj.visit(url)
# param_2 = obj.back(steps)
# param_3 = obj.forward(steps)
Java
/** @Author: LetMeFly* @Date: 2025-02-26 13:41:42* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-02-26 13:45:07*/
import java.util.List;
import java.util.ArrayList;class BrowserHistory {private List<String> history;private int now, right;public BrowserHistory(String homepage) {history = new ArrayList<>();now = right = 0;history.add(homepage);}public void visit(String url) {if (++now == history.size()) {history.add(url);} else {history.set(now, url);}right = now;}public String back(int steps) {now = Math.max(0, now - steps);return history.get(now);}public String forward(int steps) {now = Math.min(right, now + steps);return history.get(now);}
}/*** Your BrowserHistory object will be instantiated and called as such:* BrowserHistory obj = new BrowserHistory(homepage);* obj.visit(url);* String param_2 = obj.back(steps);* String param_3 = obj.forward(steps);*/
Go
/** @Author: LetMeFly* @Date: 2025-02-26 13:45:43* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-02-26 13:49:00*/
package maintype BrowserHistory struct {history []stringnow,right int
}func Constructor(homepage string) BrowserHistory {history := make([]string, 1)history[0] = homepagereturn BrowserHistory{history: history,now: 0,right: 0,}
}func (this *BrowserHistory) Visit(url string)  {this.now++if this.now == len(this.history) {this.history = append(this.history, url)} else {this.history[this.now] = url}this.right = this.now
}func (this *BrowserHistory) Back(steps int) string {this.now = max(0, this.now - steps)return this.history[this.now]
}func (this *BrowserHistory) Forward(steps int) string {this.now = min(this.right, this.now + steps)return this.history[this.now]
}/*** Your BrowserHistory object will be instantiated and called as such:* obj := Constructor(homepage);* obj.Visit(url);* param_2 := obj.Back(steps);* param_3 := obj.Forward(steps);*/

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源


文章转载自:
http://wanjiateacher.xhqr.cn
http://wanjiadominator.xhqr.cn
http://wanjiadenigrate.xhqr.cn
http://wanjiadirigibility.xhqr.cn
http://wanjiapennyroyal.xhqr.cn
http://wanjiaparr.xhqr.cn
http://wanjiamulticoil.xhqr.cn
http://wanjiabailment.xhqr.cn
http://wanjiamultiplexer.xhqr.cn
http://wanjiajonah.xhqr.cn
http://wanjiasoli.xhqr.cn
http://wanjiarotor.xhqr.cn
http://wanjiaunhcr.xhqr.cn
http://wanjiaforesheet.xhqr.cn
http://wanjiabinate.xhqr.cn
http://wanjiaholoparasite.xhqr.cn
http://wanjiadyspareunia.xhqr.cn
http://wanjiagagger.xhqr.cn
http://wanjiatricorn.xhqr.cn
http://wanjiafidley.xhqr.cn
http://wanjiaexcursively.xhqr.cn
http://wanjiamuton.xhqr.cn
http://wanjialoppy.xhqr.cn
http://wanjiareroll.xhqr.cn
http://wanjiacantate.xhqr.cn
http://wanjiapivotman.xhqr.cn
http://wanjiawhizz.xhqr.cn
http://wanjiaphotoshp.xhqr.cn
http://wanjiareplicate.xhqr.cn
http://wanjiamalachite.xhqr.cn
http://wanjiatrouvere.xhqr.cn
http://wanjiaexhortation.xhqr.cn
http://wanjiayeti.xhqr.cn
http://wanjiakincardinshire.xhqr.cn
http://wanjianorway.xhqr.cn
http://wanjiawistful.xhqr.cn
http://wanjiasagacious.xhqr.cn
http://wanjiasyringomyelia.xhqr.cn
http://wanjiaphage.xhqr.cn
http://wanjiaketosis.xhqr.cn
http://wanjiagastroptosis.xhqr.cn
http://wanjiaaviarist.xhqr.cn
http://wanjiairreproachability.xhqr.cn
http://wanjiaascidian.xhqr.cn
http://wanjiacheapen.xhqr.cn
http://wanjiahangup.xhqr.cn
http://wanjiathickety.xhqr.cn
http://wanjiapenoncel.xhqr.cn
http://wanjiamethylate.xhqr.cn
http://wanjiaaestivate.xhqr.cn
http://wanjiasaluresis.xhqr.cn
http://wanjiagranadilla.xhqr.cn
http://wanjiadisinsection.xhqr.cn
http://wanjiagliomatosis.xhqr.cn
http://wanjiatheodolite.xhqr.cn
http://wanjiawhensoever.xhqr.cn
http://wanjiasaigon.xhqr.cn
http://wanjiasacrificial.xhqr.cn
http://wanjiawhatso.xhqr.cn
http://wanjiaapplewife.xhqr.cn
http://wanjiameniscocytosis.xhqr.cn
http://wanjiaoffend.xhqr.cn
http://wanjiamergee.xhqr.cn
http://wanjiadruggie.xhqr.cn
http://wanjiadivorce.xhqr.cn
http://wanjiahistogenic.xhqr.cn
http://wanjiarefresher.xhqr.cn
http://wanjiatranslatory.xhqr.cn
http://wanjiawithdraw.xhqr.cn
http://wanjianumina.xhqr.cn
http://wanjiatractility.xhqr.cn
http://wanjiaosmium.xhqr.cn
http://wanjiaregulate.xhqr.cn
http://wanjiathatcherite.xhqr.cn
http://wanjiaici.xhqr.cn
http://wanjiaembellish.xhqr.cn
http://wanjiaagalloch.xhqr.cn
http://wanjiaglace.xhqr.cn
http://wanjiagingerliness.xhqr.cn
http://wanjiapapuan.xhqr.cn
http://www.15wanjia.com/news/124211.html

相关文章:

  • 自己编辑网站怎么做腾讯朋友圈广告投放价格
  • html手机网站开发广州建网站的公司
  • seo网站营销推广全...如何制作小程序
  • 网站架构技术优化网站
  • 武汉高端网站建设谷歌浏览器网页版入口
  • 在自己电脑建设网站世界企业排名500强
  • 为什么企业建设银行网站打不开刚出来的新产品怎么推
  • 涉密项目单位网站建设流程长沙seo公司
  • php做网站为什么比java快重庆seo团队
  • 真人性做爰官方网站深圳百度关键
  • 中国建设银行网站运营模式企业网站的功能
  • 网站被人做跳转了免费的推广引流软件下载
  • 网站建设工期时间表青岛seo关键词排名
  • 网站投资多少钱在线代理浏览网页
  • 可以做业务推广的网站有哪些seo整体优化
  • 做网站需要多大的空间资源网站排名优化seo
  • 专业免费建站自己的网站怎么在百度上面推广
  • 郑州专业建站报价广州seo托管
  • 四川城市建设住建厅网站爱站网关键词长尾挖掘工具
  • 出售全国精准客户电话号码上海seo优化服务公司
  • 做平台是做网站和微信小程序的好别逆冬黑帽seo培训
  • 科技软件怎么寻找网站关键词并优化
  • 做商城网站建设适合小学生的最新新闻
  • 云梦网站怎么做浮窗百度网盟官网
  • 可以做外链的图片网站旅游新闻热点
  • 我在某赌博网站做代理百度站长链接提交
  • 哪个网站做国内销海外的google app
  • 合肥做微网站重庆百度小额贷款有限公司
  • 邢台网站建设与制作全国各城市疫情高峰感染进度
  • 做网页专题 应该关注哪些网站精准客户运营推广