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

自己做的网站竞价优化天津seo培训

自己做的网站竞价优化,天津seo培训,html代码注释符号,有没有什么做海报字体的网站【LetMeFly】2671.频率跟踪器:俩计数哈希表 力扣题目链接:https://leetcode.cn/problems/frequency-tracker/ 请你设计并实现一个能够对其中的值进行跟踪的数据结构,并支持对频率相关查询进行应答。 实现 FrequencyTracker 类:…

【LetMeFly】2671.频率跟踪器:俩计数哈希表

力扣题目链接:https://leetcode.cn/problems/frequency-tracker/

请你设计并实现一个能够对其中的值进行跟踪的数据结构,并支持对频率相关查询进行应答。

实现 FrequencyTracker 类:

  • FrequencyTracker():使用一个空数组初始化 FrequencyTracker 对象。
  • void add(int number):添加一个 number 到数据结构中。
  • void deleteOne(int number):从数据结构中删除一个 number 。数据结构 可能不包含 number ,在这种情况下不删除任何内容。
  • bool hasFrequency(int frequency): 如果数据结构中存在出现 frequency 次的数字,则返回 true,否则返回 false

 

示例 1:

输入
["FrequencyTracker", "add", "add", "hasFrequency"]
[[], [3], [3], [2]]
输出
[null, null, null, true]解释
FrequencyTracker frequencyTracker = new FrequencyTracker();
frequencyTracker.add(3); // 数据结构现在包含 [3]
frequencyTracker.add(3); // 数据结构现在包含 [3, 3]
frequencyTracker.hasFrequency(2); // 返回 true ,因为 3 出现 2 次

示例 2:

输入
["FrequencyTracker", "add", "deleteOne", "hasFrequency"]
[[], [1], [1], [1]]
输出
[null, null, null, false]解释
FrequencyTracker frequencyTracker = new FrequencyTracker();
frequencyTracker.add(1); // 数据结构现在包含 [1]
frequencyTracker.deleteOne(1); // 数据结构现在为空 []
frequencyTracker.hasFrequency(1); // 返回 false ,因为数据结构为空

示例 3:

输入
["FrequencyTracker", "hasFrequency", "add", "hasFrequency"]
[[], [2], [3], [1]]
输出
[null, false, null, true]解释
FrequencyTracker frequencyTracker = new FrequencyTracker();
frequencyTracker.hasFrequency(2); // 返回 false ,因为数据结构为空
frequencyTracker.add(3); // 数据结构现在包含 [3]
frequencyTracker.hasFrequency(1); // 返回 true ,因为 3 出现 1 次

 

提示:

  • 1 <= number <= 105
  • 1 <= frequency <= 105
  • 最多调用 adddeleteOnehasFrequency 共计 2 * 105

方法一:俩计数哈希表

  • 使用一个哈希表val2times记录值val一共出现了多少次。
  • 使用一个哈希表times2times记录val2times中的每个times一共出现了多少次。

添加或删除元素时,更新val2times[val]的值,并更新times2times[val2times[val] (+diff)]的值。

询问是否存在出现了frequency次的数字时,直接返回times2times[frequency]是否非零。

  • 时间复杂度 O ( 1 ) / 操作 O(1)/操作 O(1)/操作
  • 空间复杂度 O ( n ) O(n) O(n)

AC代码

C++
class FrequencyTracker {
private:unordered_map<int, int> val2times, times2times;
public:FrequencyTracker() {}void add(int number, int diff=1) {int originalTimes = val2times[number];val2times[number] += diff;times2times[originalTimes]--;times2times[originalTimes + diff]++;}void deleteOne(int number) {if (val2times[number]) {add(number, -1);}}bool hasFrequency(int frequency) {return times2times[frequency];}
};
Python
# from collections import defaultdictclass FrequencyTracker:def __init__(self):self.val2times = defaultdict(int)self.times2times = defaultdict(int)def add(self, number: int, diff=1) -> None:originalTimes = self.val2times[number]self.val2times[number] += diffself.times2times[originalTimes] -= 1self.times2times[originalTimes + diff] += 1def deleteOne(self, number: int) -> None:if self.val2times[number]:self.add(number, -1)def hasFrequency(self, frequency: int) -> bool:return self.times2times[frequency] != 0

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/136922983

http://www.ds6.com.cn/news/60834.html

相关文章:

  • 给自己的网站做代言企业网站优化工具
  • html5网站制作工具交友平台
  • 淮北做网站的公司有哪些搜索引擎 磁力吧
  • 怎么做加密货币网站企业网站模板html
  • 浙江建设职业技术学校网站登录网站建站开发
  • 铜仁网站优化百度高级搜索引擎入口
  • 做网站要注意什么企业建站免费模板
  • 如何加强网站信息管理建设百度云下载
  • 自考在线做试卷的网站合肥seo
  • 卖东西怎么做网站电脑学校培训
  • 网站建设qq5月疫情最新消息
  • 济南企业营销型网站建设价格最近的电脑培训班在哪里
  • 通常做网站要多久seo是指什么
  • 360免费建站不要钱爱网站关键词挖掘工具
  • 社保汇算清缴哪个网站做的企排排官网
  • 烟台市公安局网站开发区分局地方网站建设
  • 网站制作前言公司长沙官网seo推广
  • 美工培训网站什么是网络推广工作
  • 推广通青岛seo关键字排名
  • 个人推广网站小程序推广运营的公司
  • 易企秀h5制作免费哪里有seo排名优化
  • 徐汇网站建设公司做网络推广需要多少钱
  • 北京移动端网站公司seo职业
  • 应用公园app平台官网外贸seo推广公司
  • 网站建设和网络优化律师推广网站排名
  • 制作荧光字网站百度收录查询工具官网
  • wordpress进不去了百度问答优化
  • 怎么做军事小视频网站百度搜索风云榜总榜
  • 触屏网站建设郑州seo服务技术
  • 怎样制作一个自己的网页呢软媒win7优化大师