CSP-202209-3-防疫大数据

news2024/12/24 21:42:28

CSP-202209-3-防疫大数据

解题思路

一、数据结构定义

  • 对于大模拟的题,合适的数据结构选择十分重要,正确的数据结构选择能够有效的提升解题效率
// 漫游消息结构体
struct RoamingData {
    int date, user, region; 
};

vector<RoamingData> roamingMessages[1010]; // 存储漫游消息
map<int, pair<int, int>> riskRegionDuration; // 每个地区的风险区持续时间
map<int, bool> isRiskRegion; // 每个地区是否曾被设为风险区

1.map简介

map 是 C++ 标准库中的关联容器,实现了一个有序的键-值映射。每个元素都是一个包含键和值的键值对。以下是一些关键特性:

  • 有序性map 中的元素是按照键的大小进行排序的,默认是升序

  • 唯一键:每个键在 map 中是唯一的,因此每个键只能对应一个值。如果插入重复键,新值会替代旧值

  • 查找效率map 提供了高效的查找操作,其底层实现通常是红黑树,保证了对数时间复杂度的查找操作。

用法示例:
#include <map>
#include <iostream>

int main() {
    // 创建一个map,键是字符串,值是整数
    std::map<std::string, int> myMap;

    // 插入键值对
    myMap["apple"] = 5;
    myMap["banana"] = 3;
    myMap["orange"] = 7;

    // 访问值
    std::cout << "Number of apples: " << myMap["apple"] << std::endl;

    // 遍历map
    for (const auto& pair : myMap) {
        std::cout << pair.first << ": " << pair.second << std::endl;
    }

    return 0;
}

2.pair简介

pair 是 C++ 标准库中的一个模板类,用于表示一个有序的、固定大小的元组(tuple)包含两个元素。它提供了一种方便的方法来组合两个值,通常用于需要同时返回两个值或将两个值关联的场景

  1. 成员变量

    • first:第一个元素。
    • second:第二个元素。
  2. 等号重载

    • pair& operator=(const pair& p);:允许将一个 pair 赋值给另一个。
  3. 使用示例

#include <utility>
#include <iostream>

int main() {
    // 创建一个pair,包含一个字符串和一个整数
    std::pair<std::string, int> myPair = std::make_pair("apple", 5);

    // 访问pair的成员
    std::cout << "Fruit: " << myPair.first << ", Count: " << myPair.second << std::endl;

    // 使用括号初始化列表创建pair
    std::pair<int, double> anotherPair = {42, 3.14};
    
    return 0;
}

二、风险区设置

  • 函数 setRiskRegion 的目的是将指定的地区标记为风险区,并更新该地区的风险区持续时间。下面是该函数的详细逻辑解释:
void setRiskRegion(int region, int date) {
    // 如果地区不是风险区
    if (!isRiskRegion[region]) {
        // 将该地区标记为风险区,设置风险区持续时间为 [date, date + 6]
        riskRegionDuration[region] = { date, date + 6 };
    } else {
        // 如果地区已经是风险区
        if (date <= riskRegionDuration[region].second + 1) {
            // 如果新日期与在原来风险区的有效日期内,直接延长有效期
            riskRegionDuration[region].second = date + 6;
        } else {
            // 否则,重新设置风险区持续时间为 [date, date + 6]
            riskRegionDuration[region] = { date, date + 6 };
        }
    }
    // 标记该地区为风险区
    isRiskRegion[region] = true;
}

这样,setRiskRegion 函数通过更新 riskRegionDurationisRiskRegion 这两个数据结构,有效地管理每个地区的风险区状态和持续时间。

三、检查漫游消息是否满足条件

函数 check 的目的是检查给定的漫游消息是否满足一定条件,即该消息是否在风险区域内。

bool check(int messageDate, int user, int region, int currentDate) {
    // 检查该地区是否是风险区,以及消息日期是否在指定范围内
    if (isRiskRegion[region] && 
        messageDate >= currentDate - 6 && messageDate <= currentDate && 
        messageDate >= riskRegionDuration[region].first && currentDate <= riskRegionDuration[region].second)
        return true;
    return false;
}
  1. 检查风险区:首先,检查指定的地区是否被标记为风险区(通过 isRiskRegion 的映射)。

  2. 检查消息日期范围:接着,检查消息的日期是否满足以下条件(否则必然是无效日期,因为风险地区的有效期已经结束):

    • messageDate >= currentDate - 6:消息日期在当前日期的前 6 天之后。
    • messageDate <= currentDate:消息日期在当前日期之前。
  3. 检查风险区域的日期范围:最后,检查消息日期是否在该地区的风险区域持续时间范围内,即:

    • messageDate >= riskRegionDuration[region].first:消息日期在风险区域开始日期之后。
    • currentDate <= riskRegionDuration[region].second:当前日期在风险区域结束日期之前。

如果所有条件都满足,则返回 true,表示该漫游消息在风险区域内;否则,返回 false

完整代码

  • 注意:只需遍历过去七天的漫游消息而不需要遍历全部消息,否则会时间超限。
#include <iostream>
#include <vector>
#include <map>
#include <set>
#include <algorithm>

using namespace std;

// 漫游消息结构体
struct RoamingData {
    int date, user, region; 
};

vector<RoamingData> roamingMessages[1010]; // 存储漫游消息
map<int, pair<int, int>> riskRegionDuration; // 每个地区的风险区持续时间
map<int, bool> isRiskRegion; // 每个地区是否曾被设为风险区

// 设置地区为风险区
void setRiskRegion(int region, int date) {
    if (!isRiskRegion[region])
        riskRegionDuration[region] = { date, date + 6 };
    else {
        if (date <= riskRegionDuration[region].second + 1)
            riskRegionDuration[region].second = date + 6; // 可以连起来
        else
            riskRegionDuration[region] = { date, date + 6 };
    }
    isRiskRegion[region] = true;
}

// 检查漫游消息是否满足条件
bool check(int messageDate, int user, int region, int currentDate) {
    if (isRiskRegion[region] && 
        messageDate >= currentDate - 6 && messageDate <= currentDate && 
        messageDate >= riskRegionDuration[region].first && currentDate <= riskRegionDuration[region].second)
        return true;
    return false;
}

int main() {
    int days;
    cin >> days;

    for (int currentDay = 0; currentDay < days; currentDay++) { // currentDay表示当前日期
        int riskRegions, roamingMessagesCount;
        cin >> riskRegions >> roamingMessagesCount;

        for (int i = 1; i <= riskRegions; i++) { // 读入风险区并更新
            int region;
            cin >> region;
            setRiskRegion(region, currentDay);
        }

        for (int i = 1; i <= roamingMessagesCount; i++) { // 读入漫游消息并存入
            int date, user, region;
            cin >> date >> user >> region;
            if (date <= currentDay)
                roamingMessages[currentDay].push_back({ date, user, region });
        }

        set<int> riskUserList; // 当天的风险名单

        // 遍历过去七天的漫游消息
        for (int i = (currentDay - 6 >= 0 ? currentDay - 6 : 0); i <= currentDay; i++) {
            // 对于每一天的漫游消息列表
            for (int j = 0; j < roamingMessages[i].size(); j++) {
                // 检查漫游消息是否满足条件
                if (check(roamingMessages[i][j].date, roamingMessages[i][j].user, roamingMessages[i][j].region, currentDay))
                    // 如果满足条件,将用户添加到风险用户列表
                    riskUserList.insert(roamingMessages[i][j].user);
            }
        }


        cout << currentDay << " ";
        for (const auto& ii : riskUserList) {
            cout << ii << " ";
        }
        cout << endl;
    }

    return 0;
}

请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1472540.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

阿里云服务器2024年最新价格表,高性价比配置任你选

随着云计算技术的不断发展&#xff0c;越来越多的企业和个人开始选择云服务器来搭建自己的业务平台。作为国内领先的云服务提供商&#xff0c;阿里云一直致力于为广大用户提供稳定、高效、安全的云计算服务。2024年&#xff0c;阿里云再次升级其服务器产品线&#xff0c;推出了…

FMM 笔记:st-matching(colab上执行)【官方案例解读】

在colab上运行&#xff0c;所以如何在colab上安装fmm&#xff0c;可见FMM 笔记&#xff1a;在colab上执行FMM-CSDN博客 st-matching见论文笔记&#xff1a;Map-Matching for low-sampling-rate GPS trajectories&#xff08;ST-matching&#xff09;-CSDN博客 0 导入库 from…

MySQL 数据优化技巧:提升百万级数据聚合统计速度

MySQL 数据优化技巧&#xff1a;提升百万级数据聚合统计速度 MySQL 数据优化技巧&#xff1a;提升百万级数据聚合统计速度摘要引言索引优化1. 使用合适的索引类型2. 聚簇索引的应用 查询优化3. 减少数据检索范围4. 避免全表扫描 数据库设计优化5. 合理划分数据表6. 使用分区表 …

nginx设置缓存时间

一、设置缓存时间 当网页数据返回给客户端后&#xff0c;可针对静态网页设置缓存时间&#xff0c;在配置文件内的http段内server段添加location&#xff0c;更改字段expires 1d来实现&#xff1a;避免重复请求&#xff0c;加快访问速度 第一步&#xff1a;修改主配置文件 #修…

面试经典150题【11-20】

文章目录 面试经典150题【11-20】388.O(1) 时间插入、删除和获取随机元素238.除自身以外数组的乘积134加油站135.分发糖果42. 接雨水13.罗马数字12.整数 转 罗马数字58.最后一个单词的长度14.最长公共前缀151.反转字符串中的单词 面试经典150题【11-20】 388.O(1) 时间插入、删…

IO进程:信号灯集

程序代码&#xff1a; sem.h: 1 #ifndef __SEM_H__2 #define __SEM_H__3 4 //创建信号灯集并初始化&#xff0c;semcount表示灯个数5 int open_sem(int semcount);6 7 //申请资源操作&#xff0c;semno表示灯的编号8 int P(int semid,int semno);9 10 //释放资源操作&#xff…

[LWC] Work with Data + Error Handling

目录 Overview Summary Use Cases for Interacting with Salesforce Data Handling Server Errors Sample Code Reference Overview Summary Use Cases for Interacting with Salesforce Data Handling Server Errors Sample Code Prerequisite: 1. Copy the ldsUtils f…

Python进阶学习:json.dumps()和json.dump()的区别

Python进阶学习&#xff1a;json.dumps()和json.dump()的区别 &#x1f308; 个人主页&#xff1a;高斯小哥 &#x1f525; 高质量专栏&#xff1a;Matplotlib之旅&#xff1a;零基础精通数据可视化、Python基础【高质量合集】、PyTorch零基础入门教程 &#x1f448; 希望得到您…

驻场人员严重划水,愈演愈烈,要请领导出面吗?

你有没有遇到过团队成员偷懒的情况&#xff1f;比如你们一起完成某个项目目标&#xff0c;干着干着你发现&#xff0c;就只有你和几个核心人员比较上心&#xff0c;很多人都在划水。 你可能会觉得这是因为大家工作态度不好&#xff0c;甚至怀疑他们的人品&#xff0c;忍不住想…

js里面有引用传递吗?

一&#xff1a;什么是引用传递 引用传递是相对于值传递的。那什么是值传递呢&#xff1f;值传递就是在传递过程中再复制一份&#xff0c;然后再赋值给变量&#xff0c;例如&#xff1a; let a 2; let b a;在这个代码中&#xff0c;let b a; 就是一个值传递&#xff0c;首先…

【Java程序设计】【C00276】基于Springboot的就业信息管理系统(有论文)

基于Springboot的就业信息管理系统&#xff08;有论文&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 这是一个基于Springboot的就业信息管理系统 本系统分为前台功能模块、管理员功能模块、学生功能模块、企业功能模块以及导师功能模块。 前台功能模块&…

勒索攻击新趋势,DarkSide解密工具

勒索攻击新趋势 2020年通过勒索病毒攻击已经成为网络犯罪分子热崇追捧的一种方式&#xff0c;全球几乎每天都有企业被勒索病毒攻击勒索&#xff0c;而且勒索的金额也越来越高&#xff0c;从几万美元到几千万美元不等&#xff0c;越来越多的黑客组织使用勒索病毒对企业发起攻击…

【python】学习笔记03-循环语句

3.1 whlie循环的基础语法 - while循环的语法格式 - while循环的注意事项 条件需提供布尔类型结果&#xff0c;True继续&#xff0c;False停止 空格缩进不能忘 请规划好循环终止条件&#xff0c;否则将无限循环 """ 演示while循环基础练习题&#xff1a;求1-10…

JSON:简介与基本使用

目录 什么是JSON&#xff1f; JSON的基本结构 JSON的基本使用 在JavaScript中使用JSON 创建JSON对象 解析JSON字符串 生成JSON字符串 在其他编程语言中使用JSON 总结 什么是JSON&#xff1f; JSON&#xff0c;全称为JavaScript Object Notation&#xff0c;是一种轻量…

matlab生成模拟的通信信号

matlab中rand函数生成均匀随机分布的随机数&#xff0c;randn生成正态分布的随机数&#xff1b; matlab来模拟一个通信信号&#xff1b; 通信信号通过信道时&#xff0c;研究时认为它会被叠加上服从正态分布的噪声&#xff1b; 先生成随机信号模拟要传输的信号&#xff0c;s…

C++基础知识(七:多态)

一、多态 常说的多态&#xff0c;是发生在类之间的多态 函数重载(静态多态/编译时多态) 类之间的多态(动态多态/运行时多态) 【1】前提 继承是多态的前提 虚函数 什么是多态&#xff1a;相同的代码&#xff0c;实现不同的功能 【2】函数重写(override) 必须有继承关系父类中必须…

python中的类与对象(2)

目录 一. 类的基本语法 二. 类属性的应用场景 三. 类与类之间的依赖关系 &#xff08;1&#xff09;依赖关系 &#xff08;2&#xff09;关联关系 &#xff08;3&#xff09;组合关系 四. 类的继承 一. 类的基本语法 先看一段最简单的代码&#xff1a; class Dog():d_…

JS防抖函数

场景 频繁触发耗时操作&#xff0c;仅关心最后一次的触发时使用防抖函数 代码 function debounce(fn , delay){let timer;return () > {clearTimeout(timer);timer setTimerout(()>{fn()},delay)} } 详解 触发一次函数&#xff0c;然后执行后续操作 function deboun…

消息中间件之RocketMQ源码分析(十七)

Broker CommitLog索引机制的数据结构 ConsumerQueue消费队列 主要用于消费拉取消息、更新消费位点等所用的索引。源代码参考org.apache.rocketmq.store.ConsumerQueue.该文件内保存了消息的物理位点、消息体大小、消息Tag的Hash值 物理位点:消息在CommitLog中的位点值消息体…

音乐格式转换软件有哪些?5款必备神器

音乐格式转换软件有哪些&#xff1f;音乐&#xff0c;作为人类情感的载体&#xff0c;伴随着我们生活的每一个角落。在享受音乐的同时&#xff0c;我们有时也面临着音乐格式不兼容的问题。不用担心&#xff0c;今天我将为大家揭秘五款音乐格式转换软件&#xff0c;让你的音乐之…