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;
}

相关内容

热门资讯

原创 4... 写在文章前的声明:在本文之前的说明:本文中所列的投资信息,只是一个对基金资产净值进行排行的客观描述,...
胜宏科技港股大涨49% 做完英... 记者 陈月芹 4月21日,全球AI算力板龙头胜宏科技(02476.HK)登陆港交所,上市首日股价大涨...
永赢基金:聚焦“科技新锐”,科... 数据来源:Wind,时间统计区间为2025/1/1-2026/4/21,指数过往表现不预示未来,不构...
五大阅读趋势显现!当当网发布2... 在第31个世界读书日即将来临之际及首个全民阅读活动周期间,当当网正式发布2026国民阅读洞察报告。 ...
业绩逐季回暖 老百姓大药房一季... 上证报中国证券网讯(记者 夏子航)4月22日晚,老百姓大药房发布2025年年报和2026年一季报。今...
中国20强城市大洗牌:苏州接近... 中国的城市经济竞争格局一直在变化,每年发布的GDP数据都会对城市经济实力进行重新排列。2025年榜又...
直击金宏气体股东会:预期年内氦... 《科创板日报》4月22日讯(记者 郭辉)金宏气体日前举行2025年度股东大会。会上该公司审议了公司年...
5月1日起,俄据悉将叫停哈萨克... 据行业消息人士透露,俄罗斯将于5月1日起停止经友谊管道转运哈萨克斯坦输往德国的石油,相关调整计划已送...
深化具身智能生态布局 京东携手... 4 月 22 日,京东与国内消费级人形机器人头部企业松延动力正式达成三年期战略合作。双方将围绕产品研...
原创 帮... 先问你一个问题,美伊停火今晚到期,按常理避险情绪该升温,黄金应该涨吧?结果恰恰相反——原油涨了,黄金...
300295、600889,将... 三六五网、南京化纤,将被*ST。 公司股票自4月23日开市起停牌一天,于4月24日开市起复牌并实施退...
能源大变天!外媒:羡慕中国的石... 这一次油价突破 110 美元的能源危机,着实魔幻。如果放在十年前,没人会相信中国能在这场风波中获利,...
黄金涨跌两难,现在还能上车吗? 中新网4月22日电(记者 左雨晴) 四月以来,美伊局势反复拉扯,美联储降息预期一变再变。黄金价格在4...
“我身体健康”,库克现身员工大... 当地时间4月21日,受苹果官宣CEO换届影响,公司股价盘中下探超2%,总市值失守4万亿美元关口,收盘...
库克留下一个悬念 工程师能否拯救创新节奏? 听筒Tech(ID:tingtongtech)原创 文 | 赵 森 ...
探索消费信贷与社交支付深度融合... 腾讯这一金融产品再添新功能,4月19日,北京商报记者注意到,微信分付灰度测试转账功能引发热议,在向微...
土耳其主要银行股指早盘下跌2% 每经AI快讯,4月20日,土耳其主要银行股指早盘下跌2%。 每日经济新闻
好用的OTA代运营源头厂家 在如今竞争激烈的酒旅行业中,OTA代运营服务成为了众多酒店、民宿提升竞争力的关键。但市场上的代运营厂...
成都五一出游全国热门第三 “五一”假期临近,同程旅行最新发布的《2026“五一”旅行趋势报告》显示,今年“五一”期间成都同时位...