题目2279:蓝桥杯2018年第九届真题-日志统计

#include <iostream>

#include <vector>

#include <algorithm>

using namespace std;

int main()

{

int N, D, K;

cin >> N >> D >> K;

vector< vector<int> > nums(100002); // 二维向量,外层索引是帖子id

int a = 0, b = 0; // a是时间戳,b是帖子id

// 读取输入,按帖子id归类存储

for (int i = 0; i < N; i++)

{

cin >> a >> b; // a是时间戳,b是帖子id

nums[b].push_back(a); // 将时间戳存入对应id的桶中

}

// 遍历所有可能的帖子id(0-100001)

for (int i = 0; i < 100002; i++)

{

// 特殊情况:K == 1,只要有点赞就是热帖

if (K == 1 && nums[i].size() >= 1)

{

cout << i <<endl;

continue;

}

// 如果该帖子有点赞记录

if (nums[i].size() >= 1)

{

int out = 1; // 计数器,计算满足条件的点赞数

bool backnow = false; // 是否已经找到并输出的标志

// 遍历该帖子的所有点赞时间戳

for (int j = 0; j < nums[i].size(); j++)

{

// 与其他点赞时间戳进行比较

for (int m = 0; m < nums[i].size() && m != j; m++)

{

// 判断两个时间戳是否在时间间隔D内

if (abs(nums[i][j] - nums[i][m]) < D)

{

out++; // 满足条件,计数加1

if (out >= K) // 达到热帖标准

{

cout << i <<endl;

backnow = true;

break;

}

}

}

if (backnow)

{

break; // 已经输出,结束当前帖子的判断

}

}

}

}

return 0;

}

相关推荐
tyung1 天前
Go 手写二叉堆优先队列:避开 container/heap 的性能陷阱
数据结构·后端·go
珠海西格电力1 天前
零碳园区的能源成本优势具体体现在哪些方面
大数据·人工智能·算法·架构·能源
Donk_671 天前
Shell 数组实践
linux·算法·bash
papership1 天前
【入门级-数据结构-1、线性结构:栈和队列】
数据结构
fu的博客1 天前
【数据结构14】并查集:QuickUnion、QuickFind、路径压缩
数据结构
handler011 天前
【Linux 网络】一文读懂 HTTP 协议
linux·c语言·网络·c++·笔记·网络协议·http
比特森林探险记1 天前
底层数据结构分析 go 语言中的 slice map channel interface
数据结构·golang·哈希算法
数智工坊1 天前
【DACS论文阅读】跨域混合采样如何让语义分割模型从合成数据无缝迁移到真实世界
论文阅读·人工智能·算法·机器人·无人机
And_Ii1 天前
LeetCode 026. 重排链表
算法·leetcode·链表
小明同学011 天前
C++后端项目:统一大模型接入 SDK(二)
开发语言·c++