蓝桥杯 16. 外卖店优先级

news2025/5/18 19:26:02

外卖店优先级

原题目链接

题目描述

“饱了么” 外卖系统中维护着 N 家外卖店,编号 1 ∼ N。每家外卖店都有一个优先级,初始时(0 时刻)优先级都为 0。

每经过 1 个时间单位:

  • 如果外卖店没有订单,则优先级会减少 1,最低减到 0;
  • 如果外卖店有订单,则优先级不减反加,每有一单优先级加 2。

如果某家外卖店某时刻优先级 大于 5,则会被系统加入优先缓存中;
如果优先级 小于等于 3,则会被清除出优先缓存。

给定 T 时刻以内的 M 条订单信息,请你计算 T 时刻时有多少外卖店在优先缓存中?


输入描述

第一行包含 3 个整数 N M T

接下来的 M 行,每行包含两个整数 ts id,表示 ts 时刻编号为 id 的外卖店收到一个订单。

  • 1 ≤ N, M, T ≤ 10^5
  • 1 ≤ ts ≤ T
  • 1 ≤ id ≤ N

输出描述

输出一个整数,代表在 T 时刻优先缓存中的外卖店数量。


输入输出样例

输入

2 6 6
1 1
5 2
3 1
6 2
2 1
6 2

输出

1

样例解释

6 时刻时:

  • 1 号店优先级降到 3,被移除出优先缓存;
  • 2 号店优先级升到 6,加入优先缓存。

所以最终有 1 家店(2 号)在优先缓存中。

c++代码

#include<bits/stdc++.h>

using namespace std;

int main() {
    int N, M, T, ts, id, ans = 0;
    cin >> N >> M >> T;
    vector<vector<int>> time(N + 1);
    for (int i = 0; i < M; i++) {
        cin >> ts >> id;
        time[id].push_back(ts);
    }
    for (int i = 1; i <= N; i++) sort(time[i].begin(), time[i].end());
    for (int i = 1; i <= N; i++) {
        int val = 0, last = 0, key = 0;
        for (int j = 0; j < time[i].size(); j++) {
            int k = time[i][j] - last;
            if (k <= 1) {
                val += 2;
                if (val > 5) key = 1;
            }
            else {
                val = (val - (k - 1)) > 0 ? (val - (k - 1)) : 0;
                if (val <= 3) key = 0;
                val += 2;
                if (val > 5) key = 1;
            }
            last = time[i][j];
        }
        val -= (T - last);
        if (val <= 3) key = 0;
        if (key == 1) ans++;
    }
    cout << ans;
    return 0;
}//by wqs

题目解析

思路

一开始的想法是建立T个时间戳,每个时间戳都模拟一下,看看这个店在这个时间戳是否有订单,得出这个时间戳店的得分。

这个办法是O(T*N)的时间复杂度,会超时。

其实不需要建立T个时间戳,因为一个一个时间戳地判断太慢了。

例如一个店在3时刻,5时刻,9时刻有订单。

可以在5时刻直接减去(5 - 3 - 1) * 1,因为4时刻没订单,再加上2。

在9时刻直接减去(9 - 5 - 1) * 1,因为6,7,8时刻没有订单,再加上2。

这样快得多,从5-9我们一步跨越了3个时间戳,不用一个一个时间戳判断了。

具体实现

time(N + 1), 存放每个店子的订单时间,按时间从小到大排序
for (int i = 0; i < M; i++) {
    cin >> ts >> id;
    time[id].push_back(ts);
}
for (int i = 1; i <= N; i++) sort(time[i].begin(), time[i].end());
开始模拟
for (int i = 1; i <= N; i++) {
    int val = 0, last = 0, key = 0;//val动态记录得分,last是上一个时间戳,key是判断是否在优先缓存。
    for (int j = 0; j < time[i].size(); j++) {
        int k = time[i][j] - last;//两个时间戳的距离
        if (k <= 1) {//k = 0说明,同一时间戳,有多个订单,k=1说明是连续的时间戳。
            val += 2;
            if (val > 5) key = 1;
        }
        else {//否则说明,要罚分
            val = (val - (k - 1)) > 0 ? (val - (k - 1)) : 0;//分数不低于0
            if (val <= 3) key = 0;
            val += 2;
            if (val > 5) key = 1;
        }
        last = time[i][j];
    }
    val -= (T - last);
    if (val <= 3) key = 0;
    if (key == 1) ans++;
}

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

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

相关文章

1T 服务器租用价格解析

服务器作为数据存储与处理的核心设备&#xff0c;对于企业和个人开发者而言至关重要。当涉及到租用 1T 服务器时&#xff0c;价格是大家很为关注的要点。然而&#xff0c;1T 服务器租用一个月的费用并非固定不变&#xff0c;而是受到诸多因素的综合影响。​ 影响 1T 服务器租用…

【JavaWeb】Maven(下)

1 依赖管理 1.1 依赖配置 1.1.1 基本配置 依赖&#xff1a;指当前项目运行所需要的jar包。 一个项目中可以引入多个依赖&#xff1a; 例如&#xff1a;在当前工程中&#xff0c;我们需要用到logback来记录日志&#xff0c;此时就可以在maven工程的pom.xml文件中&#xff0c;引…

openEuler24.03 LTS下安装MySQL8.0.42

目录 前提步骤 删除原有mysql及maridb数据库 安装MySQL 启动MySQL 启动查看MySQL状态 设置MySQL开机自启动 查看登录密码 登录MySQL 修改密码及支持远程连接 远程连接MySQL 前提步骤 拥有openEuler24.03 LTS环境&#xff0c;可参考&#xff1a;Vmware下安装openEule…

gflags 安装及使用

目录 引言 安装 如何用 gflags 库写代码 如何用命令行使用 gflags 库 gflags 库的其他命令行参数 引言 gflags 是 Google 开发的一个开源库&#xff0c;用于 C 应用程序中命令行参数的声明、定义 和解析。 gflags 库提供了一种简单的方式来添加、解析和文档化命令行标…

Linux面试题集合(2)

查看系统磁盘使用&#xff0c;当前目录下所有文件夹的使用情况 df -h du -h 更改目录所有人和所有组&#xff0c;包括里面的文件夹下的文件&#xff0c;递归更改 chown -R newowner:newgroup 目录名 只更改文件所有人或者只更改文件所有组 chown newowner file chgrp newgroup …

致敬经典 << KR C >> 之打印输入单词水平直方图和以每行一个单词打印输入 (练习1-12和练习1-13)

1. 前言 不知道有多少同学正在自学C/C, 无论你是一个在校学生, 还是已经是上班族. 如果你想从事或即将从事软件开发这个行业, C/C都是一个几乎必须要接触的系统级程序开发语言. 虽然现在有Rust更安全的系统级编程语言作为C/C的替代, 但作为入门, C应该还是要好好学的. C最早由B…

基于Llama3的开发应用(二):大语言模型的工业部署

大语言模型的工业部署 0 前言1 ollama部署大模型1.1 ollama简介1.2 ollama的安装1.3 启动ollama服务1.4 下载模型1.5 通过API调用模型 2 vllm部署大模型2.1 vllm简介2.2 vllm的安装2.3 启动vllm模型服务2.4 API调用 3 LMDeploy部署大模型3.1 LMDeploy简介3.2 LMDeploy的安装3.3…

windows 10 做服务器 其他电脑无法访问,怎么回事?

一般我们会先打开win10自己的防火墙策略&#xff0c;但是容易忽略 电脑之间 路由器上的防火墙&#xff0c;此时也需要查看一下&#xff0c;可以尝试先关闭路由器防火墙&#xff0c;如果可以了&#xff0c;再 设置路由器上的防火墙规则。 将路由器的上网设置 改成 路由模式 &a…

Linux进程信号处理(26)

文章目录 前言一、信号的处理时机处理情况“合适”的时机 二、用户态与内核态概念重谈进程地址空间信号的处理过程 三、信号的捕捉内核如何实现信号的捕捉&#xff1f;sigaction 四、信号部分小结五、可重入函数六、volatile七、SIGCHLD 信号总结 前言 这篇就是我们关于信号的最…

报表控件stimulsoft教程:如何在报表和仪表板中创建热图

Stimulsoft Ultimate &#xff08;原Stimulsoft Reports.Ultimate&#xff09;是用于创建报表和仪表板的通用工具集。该产品包括用于WinForms、ASP.NET、.NET Core、JavaScript、WPF、PHP、Java和其他环境的完整工具集。无需比较产品功能&#xff0c;Stimulsoft Ultimate包含了…

win32相关(字符编码)

字符编码 ASCII编码 ASCII&#xff08;American Standard Code for Information Interchange&#xff0c;美国信息交换标准代码&#xff09;是最基础的字符编码标准&#xff0c;用于在计算机和其他设备中表示文本 基本概念 7位编码&#xff1a; ASCII使用7位二进制数&#x…

使用Langfuse和RAGAS,搭建高可靠RAG应用

大家好&#xff0c;在人工智能领域&#xff0c;RAG系统融合了检索方法与生成式AI模型&#xff0c;相比纯大语言模型&#xff0c;提升了准确性、减少幻觉且更具可审计性。不过&#xff0c;在实际应用中&#xff0c;当建好RAG系统投入使用时&#xff0c;如何判断接收信息是否正确…

android studio导入项目

如果 gradle-8.0-bin.zip 没有下载成功 可以点击进入这个网站&#xff1a;https://services.gradle.org/distributions/ 找到和自己本版相同的gradle-8.0-bin.zip文件找到自己版本进行下载; 如果下载依赖失败, 可以手动下载依赖编译过程中的jar https://repo.maven.apache.org/…

Autosar Nvm下电存储实现方式-基于ETAS工具

文章目录 前言Autosar Nvm相关定义Nvm Ram Block States状态切换Nvm_WriteAll函数NvBlock配置生成代码分析及使用总结前言 Nvm中存储的数据,一般有两种存储方式,一个是立即存,一个是下电存,之前介绍过立即存的配置,本文介绍下电存的配置及实现 Autosar Nvm相关定义 Nvm…

c# 数据结构 树篇 入门树与二叉树的一切

事先声明,本文不适合对数据结构完全不懂的小白 请至少学会链表再阅读 c# 数据结构 链表篇 有关单链表的一切_c# 链表-CSDN博客 数据结构理论先导:《数据结构&#xff08;C 语言描述&#xff09;》也许是全站最良心最通俗易懂最好看的数据结构课&#xff08;最迟每周五更新~~&am…

Python Bug 修复案例分析:asyncio 事件循环异常引发的程序崩溃 两种修复方法

在 Python 异步编程的工作中&#xff0c;asyncio库为我们提供了高效处理并发任务的强大工具。然而&#xff0c;asyncio在使用过程中也可能因为一些细节处理不当而引发 Bug。下面&#xff0c;我们就来深入分析一个因asyncio事件循环异常导致程序崩溃的典型案例。兴趣的友友可以借…

题单:递归求和

宣布一个重要的事情&#xff0c;我的洛谷有个号叫 题目描述 给一个数组 a:a[0],a[1],...,a[n−1]a:a[0],a[1],...,a[n−1] 请用递归的方式出数组的所有数之和。 提示&#xff1a;递推方程 f(x)f(x−1)a[x]f(x)f(x−1)a[x]; 输入格式 第一行一个正整数 n (n≤100)n (n≤100)…

怎么在excel单元格1-5行中在原来内容前面加上固定一个字?

环境&#xff1a; WPS 2024 问题描述&#xff1a; 怎么在excel单元格1-5行中在原来内容前面加上固定一个字&#xff1f; 解决方案&#xff1a; 1.在Excel中&#xff0c;如果您想在单元格的内容前面添加一个固定的字&#xff0c;可以通过以下几种方法实现&#xff1a; 方法…

OpenHarmony 开源鸿蒙南向开发——linux下使用make交叉编译第三方库——mqtt库

准备工作 请依照这篇文章搭建环境 OpenHarmony 开源鸿蒙南向开发——linux下使用make交叉编译第三方库——环境配置_openharmony交叉编译-CSDN博客 下载 wget ftp://ftp.gnutls.org/gcrypt/gnutls/v3.5/gnutls-3.5.9.tar.xz 解压 tar -xf mkdir ./out cd ./out Cmake命…

数据结构 -- 顺序查找和折半查找

查找的基本概念 基本概念 查找&#xff1a;在数据集合中寻找满足某种条件的数据元素的过程 查找表&#xff08;查找结构&#xff09;&#xff1a;用于查找的数据集合称为查找表&#xff0c;它由同一类型的数据结构元素&#xff08;或记录&#xff09;组成 关键字&#xff1…