18年蓝桥杯 B组 8标题:日志统计

这篇博客介绍了如何解决蓝桥杯比赛中的一道日志统计问题。题目要求根据给定的日志数据,判断在指定时间段内哪些帖子收到的赞超过一定数量,被认为是‘热帖’。博主给出了输入输出格式和样例,并强调了程序运行的资源约束。解决方案可能涉及到数据结构和算法的应用,例如滑动窗口或哈希映射。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    没有考虑时间和空间复杂度问题,只是一种比较直接的一种想法,有问题轻喷;


以下是题目:

    

标题:日志统计


小明维护着一个程序员论坛。现在他收集了一份"点赞"日志,日志共有N行。其中每一行的格式是:


ts id  


表示在ts时刻编号id的帖子收到一个"赞"。  


现在小明想统计有哪些帖子曾经是"热帖"。如果一个帖子曾在任意一个长度为D的时间段内收到不少于K个赞,小明就认为这个帖子曾是"热帖"。  


具体来说,如果存在某个时刻T满足该帖在[T, T+D)这段时间内(注意是左闭右开区间)收到不少于K个赞,该帖就曾是"热帖"。  


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


【输入格式】
第一行包含三个整数N、D和K。  
以下N行每行一条日志,包含两个整数ts和id。  


对于50%的数据,1 <= K <= N <= 1000  
对于100%的数据,1 <= K <= N <= 100000 0 <= ts <= 100000 0 <= id <= 100000  


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


【输入样例】
7 10 2  
0 1  
0 10    
10 10  
10 1  
9 1
100 3  
100 3  


【输出样例】
1  
3  




资源约定:
峰值内存消耗(含虚拟机) < 256M
CPU消耗  < 1000ms




请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。


注意:
main函数需要返回0;
只使用ANSI C/ANSI C++ 标准;
不要调用依赖于编译环境或操作系统的特殊函数。
所有依赖的函数必须明确地在源文件中 #include <xxx>
不能通过工程设置而省略常用头文件。


提交程序时,注意选择所期望的语言类型和编译器类型。


#include<iostream>
#include<bits/stdc++.h>
using namespace std;

struct note_diary//一个结构体,ts和ID是为了储存提供数据 
{
	int flag=0;//flag是为了区分首发的帖子或赞 
	int ts;
	int id;
	int sum=1;//帖子点赞数 
};

int main()
{
	int n,d,k;
	cin>>n>>d>>k;
	
	note_diary note[n];//开一个结构体数组 
	for(int i=0;i<n;i++)
	{
		cin>>note[i].ts;
		cin>>note[i].id; 
	}
	
	for(int i=0;i<n;i++)
	{
		if(note[i].flag==0)
		{
			for(int j=i+1;j<n;j++)
			{
				if(note[i].id==note[j].id)//对于点赞的累加
				{
					note[j].flag = 1;
					if(note[i].ts+d > note[j].ts)//日志的时间问题判断 
					{
						note[i].sum++;
					
					}
				}
			}
		}
	}
	
	int x[n];
	for(int i=0;i<n;i++)
	{
		x[i]=0;
	}
	for(int i=0;i<n;i++)
	{
		if(note[i].flag==0 && note[i].sum>=k)//对于超过k个点赞的储存
		{
			x[i]=note[i].id;
			
		}
	}
	sort(x,x+n);//按序输出
	for(int i=0;i<n;i++)
	{
		if(x[i]!=0)
		{
			cout<<x[i]<<endl;
		}
	}
	return 0;
}

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值