LeetCode 1817. 查找用户活跃分钟数(哈希)
文章目录
- 1. 题目
- 2. 解题
1. 题目
给你用户在 LeetCode 的操作日志,和一个整数 k 。
日志用一个二维整数数组 logs 表示,其中每个 logs[i] = [IDi, timei]
表示 ID 为 IDi
的用户在 timei
分钟时执行了某个操作。
多个用户 可以同时执行操作,单个用户可以在同一分钟内执行 多个操作 。
指定用户的 用户活跃分钟数(user active minutes,UAM) 定义为用户对 LeetCode 执行操作的 唯一分钟数 。
即使一分钟内执行多个操作,也只能按一分钟计数。
请你统计用户活跃分钟数的分布情况,统计结果是一个长度为 k 且 下标从 1 开始计数 的数组 answer ,对于每个 j(1 <= j <= k),answer[j] 表示 用户活跃分钟数 等于 j 的用户数。
返回上面描述的答案数组 answer 。
示例 1:
输入:logs = [[0,5],[1,2],[0,2],[0,5],[1,3]], k = 5
输出:[0,2,0,0,0]
解释:
ID=0 的用户执行操作的分钟分别是:5 、2 和 5 。因此,该用户的用户活跃分钟数为 2(分钟 5 只计数一次)
ID=1 的用户执行操作的分钟分别是:2 和 3 。因此,该用户的用户活跃分钟数为 2
2 个用户的用户活跃分钟数都是 2 ,answer[2] 为 2 ,其余 answer[j] 的值都是 0示例 2:
输入:logs = [[1,1],[2,2],[2,3]], k = 4
输出:[1,1,0,0]
解释:
ID=1 的用户仅在分钟 1 执行单个操作。因此,该用户的用户活跃分钟数为 1
ID=2 的用户执行操作的分钟分别是:2 和 3 。因此,该用户的用户活跃分钟数为 2
1 个用户的用户活跃分钟数是 1 ,1 个用户的用户活跃分钟数是 2
因此,answer[1] = 1 ,answer[2] = 1 ,其余的值都是 0提示:
1 <= logs.length <= 10^4
0 <= IDi <= 10^9
1 <= timei <= 10^5
k 的取值范围是 [用户的最大用户活跃分钟数, 10^5]
https://leetcode-cn.com/contest/weekly-contest-235/problems/finding-the-users-active-minutes/
2. 解题
- 哈希
unordered_map<int, unordered_set<int>>
记录<用户id, 操作时间集合>
class Solution {public:vector<int> findingUsersActiveMinutes(vector<vector<int>>& logs, int k) {unordered_map<int, unordered_set<int>> m; // 用户id, 操作时间集合for(auto& log : logs){m[log[0]].insert(log[1]);}vector<int> ans(k);for(auto& mi : m){ans[mi.second.size()-1]++;}return ans;}
};
280 ms 83.5 MB C++
我的CSDN博客地址 https://michael.blog.csdn.net/
长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
LeetCode 1817. 查找用户活跃分钟数(哈希)相关推荐
- LeetCode 890. 查找和替换模式(哈希表)
1. 题目 你有一个单词列表 words 和一个模式 pattern,你想知道 words 中的哪些单词与模式匹配. 如果存在字母的排列 p ,使得将模式中的每个字母 x 替换为 p(x) 之后,我们 ...
- Java黑皮书课后题第6章:**6.25(将毫秒转化成小时、分钟、秒数)使用下面的方法头,编写一个将毫秒数转换成小时数、分钟数和描述的方法,返回形式如“小时:分钟:秒“
6.25(将毫秒转化成小时.分钟.秒数)使用下面的方法头,编写一个将毫秒数转换成小时数.分钟数和描述的方法,返回形式如"小时:分钟:秒" 题目 题目描述 破题 代码 运行实例 题目 ...
- SQL Server时间粒度系列----第6节基于当前日的小时数和分钟数与mysql unix_timestamp和from_unixtime的mssql实现...
本文目录列表: 1.基于当前日的小时数和分钟数 2.mysql unix_timestamp和from_unixtime的mssql实现 3.总结语 4.参考清单列表 基于当前日的小时数和分钟数 ...
- 用户活跃/用户价值度分析
用户活跃.用户价制度分析的在数据分析师的日常工作中经常会碰到,如何根据公司的业务情况对本公司的用户做活跃和价制度的划分是一种常规化的分析工作. 在用户生命周期中,对每个用户进行群体划分,有针对性地做分 ...
- 华为推送服务 | 简单一招,提高用户活跃和留存
如今互联网红利见顶,拉新成本逐渐增高,与此同时,用户花在某个特定应用的时间也越来越少.据<2019年Q4移动互联网行业数据研究报告>指出,过去一年里,移动网民人均安装APP总量持续增长至6 ...
- C语言把分钟数转换成小时和分钟
题目:编写一个程序,把用分钟表示的时间转换成用小时和分钟表示的时间.使用#define或const创建一个表示60的符号常量或const变量.通过while循环让用户重复输入值,直到用户输入小于或等于 ...
- LeetCode刷题之575.分糖果
LeetCode刷题之575.分糖果 我不知道将去向何方,但我已在路上! 时光匆匆,虽未曾谋面,却相遇于斯,实在是莫大的缘分,感谢您的到访 ! 题目: 给定一个偶数长度的数组,其中不同的数字代表着不同 ...
- 第六章第二十五题(将毫秒数转换成小时数、分钟数和秒数)(Convert milliseconds to hours, minutes, and seconds)
**6.25(将毫秒数转换成小时数.分钟数和秒数)使用下面的方法头,编写一个将毫秒数转换成小时数.分钟数和秒数的方法. public static String convertMillis(long ...
- 将毫秒数转换成小时数、分钟数和秒数。
使用下面的方法,编写一个将毫秒数转换成小时数.分钟数和秒数的方法: public static String convertMillis (long millis) 该方法返回形如"小时:分 ...
最新文章
- 她是985高校的90后博导!常被认成“师姐”,喜欢减压式教学
- numpy.matmul处理一维数组的 3维以上的性质
- 前沿报告|AI系列报告之:智能计算芯片
- 简单的REST的框架实现
- 一个娃娃竟然拍出50万......
- 第48次《中国互联网络发展状况统计报告》
- h5 登录页面_一份写给新手的微信H5页面制作流程介绍
- WebStorm如何设置默认游览器
- 20190825 On Java8 第十二章 集合
- JS动态插入插件后,不能马上使用,必须刷新
- 源码专题之spring设计模式:策略模式、原型模式、模板模式
- 学习笔记(4):思科CCNA模拟器Packet Tracer使用入门-路由器的使用(2811、2911)
- Mac开发-NSTextView软回车转换为硬回车
- 补码,负数比整数多表示一个
- JAV迷你共享单车项目
- 工作之路---记录LZ如何在两年半的时间内升为PM
- 后缀名htm与html的区别
- ffmpeg:制作gif / 提取视频帧为图片
- 新手做电商直播带货怎么和快递合作谈价格
- 采样率与频率之间的关系