防疫大数据 第27次CCF-CSP计算机软件能力认证

cpp 复制代码
#include<iostream>
#include<unordered_map>
#include<unordered_set>
#include<bits/stdc++.h>
using namespace std;
int n;
unordered_map<int, vector<vector<int>>> datas;
unordered_map<int, vector<int>> risks;//value代表每个地区的风险时间
bool check(int r,int d1,int d) {
	//r为地区 d1-d必须位于r的风险区域内
	vector<vector<int>> result;
	for (int num : risks[r]) {
		if (result.size() == 0) {
			result.push_back({ num,num + 6 });
		}
		else {
			if (result[result.size() - 1][1] >= num-1) {
				int start = result[result.size() - 1][0];
				int end = result[result.size() - 1][1];
				result.pop_back();
				result.push_back({ min(start,num),max(end,num+6) });
			}
			else {//不重合
				result.push_back({num,num+6});
			}
		}
	}
	//现在每一个区域之间都是离散的
	for (vector<int> qj : result) {
		if (qj[0] <= d1 && d <= qj[1]) {
			return true;
		}
	}
	return false;
}
int main() {
	cin >> n;
	for (int i = 0; i < n; i++) {
		int r, m;
		cin >> r >> m;
		while (r--) {
			int p;
			cin >> p;
			//加入风险时间
			risks[p].push_back(i);
		}
		while (m--) {
			int d, u, r;
			cin >> d >> u >> r;
			datas[i].push_back(vector<int>({ d,u,r }));
		}
		//处理当天信息
		unordered_set<int> res;
		//遍历七日的漫游数据
		for (int j = i-6; j <=i; j++) {
			if (j < 0) continue;
			for (vector<int> message : datas[j]) {
				int d1 = message[0];//到达日期
				int d = i;
				int u = message[1];//用户
				int r = message[2];//地区
				if (d1 <= i && d1 > i - 7) {
					if (check(r, d1, d)) {
						res.insert(u);
					}
				}
			}
		}
		vector<int> result = vector<int>(res.begin(), res.end());
		sort(result.begin(), result.end());
		cout << i << " ";
		for (int num : result) {
			cout << num << " ";
		}
		cout << endl;
	}
}

70代码:超时原因为区间不需要保存所有 只保存最新的就可以 因为过7天之后 前面的区间一定不再是风险区间了不需要保存 ,只需要保存最新的信息即可;

相关推荐
地平线开发者7 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮7 小时前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者8 小时前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考8 小时前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx11 小时前
CART决策树基本原理
算法·机器学习
Wect12 小时前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱12 小时前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
肆忆_15 小时前
# 用 5 个问题学懂 C++ 虚函数(入门级)
c++
武子康18 小时前
大数据-237 离线数仓 - Hive 广告业务实战:ODS→DWD 事件解析、广告明细与转化分析落地
大数据·后端·apache hive
不想写代码的星星19 小时前
虚函数表:C++ 多态背后的那个男人
c++