P8685 [蓝桥杯 2019 省 A] 外卖店优先级--优先队列“数组”!!!!!

P8685 [蓝桥杯 2019 省 A] 外卖店优先级

    • 题目
  • 解析
    • 优先队列
      • 如何判断是否使用优先队列?
      • 省略规则
      • 优先队列常用操作
      • 大顶堆 vs 小顶堆
      • 定义队列h
      • 队列数组
    • 代码

题目

在这里插入图片描述

解析

每个外卖店会在不同的时间点收到订单,我们可以看见测试用例的时间顺序是不同的,而且有在相同时间内有多个订单的店铺

如果我们按输入的顺序来计算,显而易见是求不出来的,所以我们需要按时间顺序来处理订单,然后计算优先级,并判断是否在优先缓存中。

那么问题来了,我们应该如何对时间进行排序,用数组然后用sort?但是一个id,对应了多个时间点,一维数组显然难以实现,用二维数组?(不知道行不行,但是我知道太复杂了)

这里我们会想要一个以id来区分的存储器存储时间点,并且能够对时间点排序

没错没错,就只有他了优先队列数组【优先队列还不行,优先队列不能存储id】

优先队列的作用:
1.按时间顺序处理订单,避免手动排序的复杂性。
2.不同下标的队列数组,内容互不影响。
3.时间复杂度:每个订单插入和取出操作的时间复杂度为 O(log m),总复杂度为 O(m log m + n),适用于大规模数据。

找到存取id和时间点的最佳容器后,我们需要遍历每一个id,计算时间点,判断是否在优先缓存中。

注意:题目中问的是t时刻,有些店铺在t时刻前就没有订单了,我们还需计算最后一个时刻到t时刻减少的优先级

if (last != t) {
			pri -= (t - last);
			if (pri < 0)
				pri = 0;
		}
		if (in && pri <= 3)
			in = false;

优先队列

priority_queue<int, vector<int>, greater<int>> h;

优先队列 (priority_queue):
是 C++ 中一种特殊的数据结构,它和普通队列(先进先出)不同,元素的出队顺序由优先级决定。
它是 C++ STL 中的一种容器,默认是大顶堆(队首元素最大)。
但这里通过 greater 指定为小顶堆(队首元素最小)。
priority_queue 的完整模板参数列表如下:

如何判断是否使用优先队列?

1.是否要求动态获取最大值/最小值?
是 → 优先队列。
2.是否需要按特定顺序处理元素?
是 → 优先队列。
3.是否涉及贪心策略(每次选最优解)?
是 → 优先队列。

省略规则

template<
    class T,                          // 元素类型(必须明确指定)
    class Container = vector<T>,      // 底层容器(默认是 vector<T>)
    class Compare = less<T>          // 比较函数(默认是大顶堆)
> 
class priority_queue;

元素类型 T:必须明确指定(如 int)。

底层容器 Container:可以省略,默认用 vector。
比较函数 Compare:可以省略,默认用 less(大顶堆)。

什么时候可以完全省略?
大顶堆(默认行为):可以省略底层容器和比较函数:

priority_queue<int> h; // 等价于 priority_queue<int, vector<int>, less<int>>

优先队列常用操作

在这里插入图片描述

大顶堆 vs 小顶堆

在这里插入图片描述

定义队列h

#include <bits/stdc++.h>
using namespace std;

int main() {
    priority_queue<int, vector<int>, greater<int>> h; // 单个队列
    for (int i = 0; i < 3; i++) {
        int x;
        cin >> x;
        h.push(x); // 所有元素插入同一个队列
    }
    while (!h.empty()) {
        cout << h.top() << ' '; // 按小顶堆顺序输出:1 2 3
        h.pop();
    }
    return 0;
}

队列数组

下述定义的为队列数组h[n],每个队列都是相互独立的,队列自动排序。

#include <bits/stdc++.h>
using namespace std;

int main() {
	priority_queue<int, vector<int>, greater<int>> h[3]; // 3 个队列
	// 为每个队列插入多个元素
	h[0].push(3);
	h[0].push(1);
	h[0].push(2); // 队列0排序后:1 2 3
	h[1].push(5);
	h[1].push(4);              // 队列1排序后:4 5

	// 输出每个队列的内容
	for (int i = 0; i < 3; i++) {
		while (!h[i].empty()) {
			cout << h[i].top() << ' ';
			h[i].pop();
		}
		cout << endl;
	}
	return 0;
}

代码

#include <bits/stdc++.h>
using namespace std;
int n, t, m, cnt;

int main() {
	cin >> n >> m >> t;
	//建优先队列数组
	priority_queue<int, vector<int>, greater<int>> h[100010];
	
	for (int i = 1; i <= m; i++) {
		int ts, id;
		cin >> ts >> id;
		h[id].push(ts);
	}
	//遍历每家店铺
	for (int i = 1; i <= n; i++) {
		int last = 0, pri = 0;//last:上一次订单时间,pri:记优先级
		bool in = false;//判定是否在优先级队列中
		//遍历商铺的所有订单
		while (!h[i].empty()) {
			int x = h[i].top();//x时刻
			h[i].pop();
		//判断是否有同一时刻多次订单
			if (last != x) {
			//计算时间差,减少优先级
				pri -= (x - last - 1);
			//优先级不能为负
				if (pri < 0)
					pri = 0;
			}
			//判定是否移除优先级
			if (in && pri <= 3)
				in = false;
			//增加优先级
			pri += 2;
			last = x;
			//判定是否加入缓存
			if (pri > 5) {
				in = true;
			}
		}
		//判断T时刻该店铺是否在优先缓存中
		if (last != t) {
			pri -= (t - last);
			if (pri < 0)
				pri = 0;
		}
		if (in && pri <= 3)
			in = false;
		if (in) {
			cnt++;
		}
	}
	cout << cnt;
	return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

使用苹果M芯片打包Docker Image无法在amd64环境下运行

问题所在 使用苹果M芯片打包Docker Image无法在amd64环境下运行&#xff0c;因为arm环境下打包docker默认打包为arm格式&#xff0c;可以使用以下命令查看&#xff1a; docker inspect <ImageID>找到Architecture&#xff0c;可以发现 解决方法 在docker-compose.ym…

低代码开发直聘管理系统

低代码 DeepSeek 组合的方式开发直聘管理系统&#xff0c;兼职是开挂的存在。整个管理后台系统 小程序端接口的输出&#xff0c;只花了两个星期不到。 一、技术栈 后端&#xff1a;SpringBoot mybatis MySQL Redis 前端&#xff1a;Vue elementui 二、整体效果 三、表结…

MySQL的安装及配置

一.以安装包方式下载 1.进入MySQL官网&#xff0c;下载安装包 官网链接&#xff1a;https://downloads.mysql.com/archives/installer/ 2.安装MySQL 二.压缩包方式下载 下载位置&#xff1a;mysql下载位置 解压缩后位置&#xff1a;D:\mysql-8.0.15-winx64 在主目录下复制…

CI/CD—Jenkins配置一次完整的jar自动化发布流程

背景&#xff1a; 实现设想&#xff1a; 要创建自动化发布&#xff0c;需要准备一台测试服务器提前安装好java运行所需的环境&#xff0c;JDK版本最好和Windows开发机器上的版本一致&#xff0c;在Jenkins上配置将构建好的jar上传到测试服务器上&#xff0c;测试服务器自动启动…

C++蓝桥杯皮亚诺曲线距离求解

C蓝桥杯皮亚诺曲线距离求解 一、题目概述二、解题分析2.1解题思路2.2k值范围限制 三、实现代码四、代码测试4.1蓝桥杯测试平台4.2直接传入原始输入的k值4.3限制k值大小4.4pow函数求整数高次幂存在误差4.5满分代码 附录error: ‘long long int y1’ redeclared as different kin…

开源!速度100Kb/s的有线和无线双模ESP32S3芯片的DAP-Link调试器

开源&#xff01;速度100Kb/s的有线和无线双模ESP32S3芯片的DAP-Link调试器 目录 开源&#xff01;速度100Kb/s的有线和无线双模ESP32S3芯片的DAP-Link调试器本项目未经授权&#xff0c;禁止商用&#xff01;本项目未经授权&#xff0c;禁止商用&#xff01;本项目未经授权&…

简记_硬件系统设计之需求分析要点

目录 一、 功能需求 二、 整体性能需求 三、 用户接口需求 四、 功耗需求 五、 成本需求 六、 IP和NEMA防护等级需求 七、 认证需求 功能需求 供电方式及防护 供电方式&#xff1a;市电供电、外置直流稳压电源供电、电池供电、PoE&#xff08;Power Over Ether…

python连接deepseek api实例

步骤一&#xff1a;安装必要的库&#xff0c;如openai&#xff1b; 步骤二&#xff1a;deepseek平台申请api&#xff0c;并充值&#xff08;可先充10元&#xff09;&#xff0c;费用大概一个查询2分钱的样子&#xff1b; 步骤三&#xff1a;设置环境变量&#xff1a;DEEPSEEK…

抽象类与普通类

抽象类和普通类的区别&#xff1a; 抽象类其实就是普通类和接口&#xff08;完全抽象&#xff09;之间的设计工具。通过抽象类&#xff0c;可以更灵活地构建可扩展、可维护的类层次结构。抽象类的核心价值在于平衡代码复用和规范约束。 示例&#xff1a;

免费生成可下载ppt

1.天工AI 免费的&#xff0c;模版很少&#xff0c;效果不是很好&#xff1b; 2.Kimi 免费的&#xff0c;模版不多&#xff0c;效果还可以&#xff1b;

【解决哈希冲突】

哈希冲突 如果两个不同的 key 通过哈希函数得到了相同的索引&#xff0c;这种情况就叫做「哈希冲突」。 哈希冲突不可能避免&#xff0c;只能在算法层面妥善处理出现哈希冲突的情况。 哈希冲突是一定会出现的&#xff0c;因为这个 hash 函数相当于是把一个无穷大的空间映射到…

基于LabVIEW的脚本化子VI动态生成

该示例展示了一种利用LabVIEW VI脚本&#xff08;VI Scripting&#xff09;技术&#xff0c;通过程序化方式动态生成并替换子VI的解决方案。核心逻辑为&#xff1a;基于预定义的模板VI&#xff0c;根据用户选择的数学操作&#xff08;加法或乘法&#xff09;&#xff0c;自动生…

谷歌AI最新发布的可微分逻辑元胞自动机(DiffLogic CA)

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

如何使用Postman,通过Mock的方式测试我们的API

这篇文章将教会大家如何利用 postman&#xff0c;通过 Mock 的方式测试我们的 API。 什么是 Mock Mock 是一项特殊的测试技巧&#xff0c;可以在没有依赖项的情况下进行单元测试。通常情况下&#xff0c;Mock 与其他方法的主要区别就是&#xff0c;用于取代代码依赖项的模拟对…

pytest基础知识

pytest知识了解 pytest的基础知识了解&#xff1a;Python测试框架之pytest详解_lovedingd的博客-CSDN博客_pytest框架 (包含设置断点&#xff0c;pdb&#xff0c;获取最慢的10个用例的执行耗时) pytest-pytest.main()运行测试用例&#xff0c;pytest参数&#xff1a; pytest-…

LM Studio 替换源的方式解决huggingface.co无法访问的问题

安装软件完成之后&#xff0c;不要打开&#xff0c;打开了就直接关闭 在安装目录下&#xff0c;比如我安装在E:\Program Files\LM Studio 下面三个文件中的huggingface.co全部替换为hf-mirror.com然后再打开即可。 E:\Program Files\LM Studio\resources\app\.webpack\rende…

【含文档+PPT+源码】基于微信小程序的乡村振兴民宿管理系统

项目介绍 本课程演示的是一款基于微信小程序的乡村振兴民宿管理系统&#xff0c;主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Java 学习者。 1.包含&#xff1a;项目源码、项目文档、数据库脚本、软件工具等所有资料 2.带你从零开始部署运行本套系统 3.该…

五、OpenGL中Shader与C++数据传输

文章目录 一、概述二、Shader 代码文件的基本格式三、Shader的向量语法介绍四、Shader之间的数据传输五、Shader与C的数据传输uniform六、完整示例 一、概述 在 OpenGL 中&#xff0c;Shader&#xff08;着色器&#xff09;使用 GLSL&#xff08;OpenGL Shading Language&…

docker不停机部署

背景 最近做大疆项目时&#xff0c;后台更新部署时&#xff0c;机场和无人机就会掉线。设备自动重连注册时间比较长&#xff0c;应用长时间不可用。所以需要灰色发布服务。docker-compose的swarm模式可解决此问题。 服务构建脚本Dockerfile # 使用官方Java基础镜像&#xff…

工作记录 2016-12-22

工作记录 2016-12-22 更新的问题 1、修改了Job Summary的Bill Amount的Bug。 2、修改了Account #的宽度。 3、修改了Clearinghouse Status的默认查询的条件。 4、修改了Upload Files的Add File的bug。 5、Pending Pool、Missing Infos加了Write Off&#xff0c;修改了Histor…