防疫大数据 第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天之后 前面的区间一定不再是风险区间了不需要保存 ,只需要保存最新的信息即可;

相关推荐
xixixi777771 分钟前
Token 经济引爆 AI 产业加速:从百模大战到百虾大战,谁在定义 2026 的中国 AI?
大数据·人工智能·机器学习·ai·大模型·算力·通信
郝学胜-神的一滴1 分钟前
[简化版 GAMES 101] 计算机图形学 04:二维变换上
c++·算法·unity·godot·图形渲染·unreal engine·cesium
ZC跨境爬虫2 分钟前
海南大学交友平台开发实战day7(实现核心匹配算法+解决JSON请求报错问题)
前端·python·算法·html·json
来日可期13143 分钟前
C/C++ 反常识记录(1)—— 那些容易踩坑的语法细节
c语言·开发语言·c++
计算机安禾6 分钟前
【数据结构与算法】第41篇:图论(五):拓扑排序与关键路径
c语言·数据结构·c++·算法·图论·visual studio
Q741_1479 分钟前
每日一题 力扣 1320. 二指输入的的最小距离 动态规划 C++ 题解
c++·算法·leetcode·动态规划
实心儿儿10 分钟前
C++ —— C++11(2)
开发语言·c++
加油JIAX11 分钟前
C++11特性
c++
Gent_倪16 分钟前
数据建模概念解析
大数据·数据建模
wfbcg17 分钟前
每日算法练习:LeetCode 76. 最小覆盖子串 ✅
算法·leetcode·职场和发展