热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

5.2同向尺取法——【日志统计】

文章目录题目描述输入描述输出描述输入输出样例最终代码1.cc2.java3.python过程理解题目描述小明维护着一个程序员论坛。现在他收集了一份点赞日志,日志

文章目录

  • 题目描述
  • 输入描述
  • 输出描述
  • 输入输出样例
  • 最终代码
    • 1. c/c++
    • 2. java
    • 3. python
  • 过程理解


题目描述

小明维护着一个程序员论坛。现在他收集了一份"点赞"日志,日志共有N行。

其中每一行的格式是:
ts id
表示在ts时刻编号id的帖子收到一个"赞"。

现在小明想统计有哪些帖子曾经是"热帖”。
如果一个帖子曾在任意一个长度为D的时间段内收到不少于K个赞,小明就认为这个帖子曾是"热帖”。
具体来说,如果存在某个时刻T满足该帖在[T,T+D)这段时间内(注意是左闭右开区间)收到不少于K个赞,该帖就曾是"热帖”

给定日志,请你帮助小明统计出所有曾是"热帖”的帖子编号。

输入描述

在这里插入图片描述


输出描述

按从小到大的顺序输出热帖id。每个id一行。


输入输出样例

输入:

7 10 2
0 1
0 10
10 10
10 1
9 1
100 3
100 3

输出:

1
3




最终代码

1. c/c++

#include
using namespace std;const int N = 100005;
int num[N]; //num[i]:记录id=i的帖子的赞的数量
int flag[N]; //flag[i]:id=i的贴子曾是热帖struct post
{int id;int ts;
}p[N]; //记录帖子int cmp(post x,post y){ return x.ts < y.ts; } //按时间从小到大排序int main()
{int n,d,k;cin>>n>>d>>k;for(int i&#61;0;i<n;i&#43;&#43;)cin>>p[i].ts>>p[i].id;sort(p,p&#43;n,cmp); //按时间从小到大排序for(int i&#61;0,j&#61;0;i<n;i&#43;&#43;){num[p[i].id]&#43;&#43;;while(p[i].ts-p[j].ts >&#61; d){num[p[j].id]--; //随着时间流逝&#xff0c;d之前的每个贴的次数都减1j&#43;&#43;;}//在区间[i-d,i)上达到k个赞if(num[p[i].id] >&#61; k)flag[p[i].id]&#61;1;}for(int i&#61;0;i<N;i&#43;&#43;)if(flag[i]&#61;&#61;1)cout<<i<<endl;return 0;
}




2. java





3. python





过程理解

推荐阅读
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
  • 火星商店问题:线段树分治与持久化Trie树的应用
    本题涉及编号为1至n的火星商店,每个商店有一个永久商品价值v。操作包括每天在指定商店增加一个新商品,以及查询某段时间内某些商店中所有商品(含永久商品)与给定密码值的最大异或结果。通过线段树分治和持久化Trie树来高效解决此问题。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文探讨了如何在模运算下高效计算组合数C(n, m),并详细介绍了乘法逆元的应用。通过扩展欧几里得算法求解乘法逆元,从而实现除法取余的计算。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • This document outlines the recommended naming conventions for HTML attributes in Fast Components, focusing on readability and consistency with existing standards. ... [详细]
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
  • Linux设备驱动程序:异步时间操作与调度机制
    本文介绍了Linux内核中的几种异步延迟操作方法,包括内核定时器、tasklet机制和工作队列。这些机制允许在未来的某个时间点执行任务,而无需阻塞当前线程,从而提高系统的响应性和效率。 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • 本文探讨了 C++ 中普通数组和标准库类型 vector 的初始化方法。普通数组具有固定长度,而 vector 是一种可扩展的容器,允许动态调整大小。文章详细介绍了不同初始化方式及其应用场景,并提供了代码示例以加深理解。 ... [详细]
author-avatar
吾爱九-九九
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有