202209-3 CCF 防疫大数据 满分题解(超详细讲解 + 注释代码) + 解题思路(STL模拟)
创始人
2025-06-01 20:54:40
0

问题描述

在这里插入图片描述

解题思路

首先题意是给出n天的漫游信息以及n天的风险地区名单
求n天的风险人群

根据题意肯定要将漫游信息存储下来,用结构体数组比较合适
在判断该用户是否是风险人群时,需要判断[d1, d]区间内地点r是否是风险地区,所以需要把地点r的风险起始终止时间存储下来,可以采用map结合pair
并且开一个数组存储每天的风险人群答案,最后再排序去重输出
以下是我的数据结构,可参考,还有其他定义形式
在这里插入图片描述
然后就是读入每一天的漫游信息以及风险地区
当天就得出当天的风险人群
首先得到风险地区后,先更新每一个地区的风险时间段
在d天确认地点r为风险地区,那么目前r的风险终止时间一定会被更新成d + 6(未来7天内)
如果之前r不是风险地区或者d - 1天时已经不是风险地区,那么需要将r的风险起始时间更新为d,否则不更新
在这里插入图片描述

有了地区的风险时间段之后,就可以根据题目给出的条件判断这个用户是否是风险人群就可以了
在这里插入图片描述
对应的代码
在这里插入图片描述
最后将答案每一天依次输出,输出前进行编号的排序去重,存在重复的原因是因为漫游数据存在重复数据和多地访问数据
在这里插入图片描述


代码实现

#include 
#include 
#include 
#include 
#include 
#include using namespace std;struct node //存储漫游信息
{int day;int user;int address;
};vector  alls[1010]; //存储每一天的有用的漫游信息
vector  res[1010]; //存储每一天的风险人群
unordered_map > A; //存储地点r的风险时间段
int n, r, m;int main()
{scanf("%d", &n);for (int d = 0; d < n; d ++){scanf("%d%d", &r, &m);for (int i = 0; i < r; i ++){int x;scanf("%d", &x); //地点x在d天被确认为风险地区//如果x之前不是风险地区或者d-1天时x已经不是风险地区了if (A.count(x) == 0 || d - A[x].second > 1) A[x].first = d; //更新风险时间段的起点//更新风险时间的终点为 第 d + 6天A[x].second = d + 6;}for (int i = 0; i < m; i ++){int d1, u, a;scanf("%d%d%d", &d1, &u, &a);//如果这天漫游信息中的地点不是风险地区或者当天已经不是风险地区或者是七天前的无效信息,则不需要保存if (A.count(a) == 0 || A[a].second < d || d1 < d - 6) continue;node t = {d1, u, a};alls[d].push_back(t); //存入当天的漫游信息}//处理[d-6, d]天中收到的有效漫游信息,得到风险人群for (int i = max(0, d - 6); i <= d; i ++){for (int c = 0; c < alls[i].size(); c ++) //遍历第i天收到的漫游信息{int d1 = alls[i][c].day, u = alls[i][c].user, a = alls[i][c].address;//当前这个地区是风险地区//并且漫游信息是七天之内收到的漫游信息//并且[d1, d]这个时间段这个地区都是风险地区//则将这个人列入危险人群if (A.count(a) && d1 >= d - 6 && d1 >= A[a].first && d <= A[a].second) res[d].push_back(u);}}}for (int i = 0; i < n; i ++){sort(res[i].begin(), res[i].end()); //排序//处理重复数据和多地点数据,可能一个人被列入多次res[i].erase(unique(res[i].begin(), res[i].end()), res[i].end());  //去重printf("%d", i);for (int j = 0; j < res[i].size(); j ++) printf(" %d", res[i][j]); //输出printf("\n");}return 0;
}

相关内容

热门资讯

提振消费,如何增强供需适配性 云南大理白族自治州,游客(左)与摄影师一起挑选照片。 北京朝阳区,一名智能柜补货员在卸货。 以上图...
贝仕达克:预计2025年度净利... 每经AI快讯,贝仕达克1月30日晚间发布业绩预告,预计2025年归属于上市公司股东的净利润860万元...
英媒:随着就业市场降温,美国大... 来源:格隆汇APP 格隆汇1月30日|据英国金融时报,本周,美国的一些大型企业公布了裁员计划,预计将...
终结5连败!德约3-2逆转辛纳... 北京时间1月30日,2026赛季网球大满贯澳大利亚公开赛继续进行,在男单下半区的半决赛中,塞尔维亚天...
去年辽宁非金融企业债务融资达6... 1月30日,人民银行辽宁省分行召开2026年一季度新闻发布会,介绍2025年度辽宁省金融运行主要情况...
“大V带货”遭监管重拳:基金销... 记者 洪小棠 1月29日,证监会证券基金机构监管司发布了新一期《机构监管情况通报》(下称《通报》),...
ST宁科完成组织架构重大调整 ... 来源:新浪财经-鹰眼工作室 【财经网讯】宁夏中科生物科技股份有限公司(证券代码:600165,股票简...
原创 i... 很多人看到苹果这份“史上最强”季度成绩单时,第一反应都是:这销量也太夸张了吧? 尤其是大中华区 ...
Cloudflare入驻B站和... IT之家 1 月 30 日消息,Cloudflare 宣布入驻B站和小红书,认证显示为“Cloudf...
首日涨超160% 智能制造装备... 上证报中国证券网讯(记者 张雪)1月30日,美德乐正式登陆北交所。截至当日收盘,公司股价报109.5...
特朗普提名下一任美联储主席 据新华社消息,美国总统特朗普30日提名美联储前理事凯文·沃什为下任美联储主席,这一提名还需获得参议院...
由盈转亏、业绩下滑超85%!2... 面对每天上千份上市公司公告该看哪些?重大事项公告动辄几十页几百页重点是啥?公告里一堆专业术语不知道算...
原创 华... 金价的上涨和美元的下跌已经让整个依赖美西方货币体系和金融体系获利的人感受到了巨大的威胁。 在美国财政...
康佳集团原董事长周彬、原副总裁... 老牌家电巨头康佳集团(000016)在经历控制权变更与管理层换血的震荡期后,迎来了更为剧烈的“余震”...
安诚财险2025年揽收保费52... (图片来源:视觉中国) 蓝鲸新闻1月30日讯(记者 陈晓娟)日前,安诚财产保险股份有限公司(下称“安...
国际金价、银价,暴跌! 据新华社1月30日消息,国际黄金和白银价格1月29日上演“过山车”行情,双双站上高位后又暴跌,市场剧...
A股115家半导体公司2025... 近期,A股半导体行业上市公司陆续披露半年度业绩预告。据集微网统计,截至2026年1月30日,在已披露...
一图读懂服务消费新政:涉及交通... 红星资本局1月30日消息,为优化和扩大服务供给,聚焦重点领域、潜力领域,加快培育服务消费新增长点,促...
沪农商行:着力于稳健运营、控制... 证券日报网1月30日讯 ,沪农商行在接受调研者提问时表示,投资交易策略方面,公司将基于对2026年宏...
实力“圈粉”全球客:去年上海离... 记者从市税务局获悉,2025年境外旅客在沪办理退税申请单数量同比增长3倍,退税商品销售额和退税额均增...