华为OD机试题【支持优先级的队列】【2023 B卷 100分】

在这里插入图片描述

文章目录

  • 🎯 前言
  • 🎯 题目描述
  • 🎯 解题思路
    • 📙 Python代码实现
    • 📗 Java代码实现
    • 📘 C语言代码实现


🎯 前言

🏆 《华为机试真题》专栏含2023年牛客网面经、华为面经试题、华为OD机试真题最新试题。

🏆 华为机试有三道题,第一道和第二道属于简单题,分值为100分,第三道为困难题,分值为200分,总分400分,150分钟考试时间。

🏆 如果您在准备华为的面试,期间有想了解的可以私信我,我会尽可能帮您解答,也可以给您一些建议!

🎯 题目描述

实现一个支持优先级的队列,高优先级先出队列,同优先级时先进先出。

如果两个输入数据和优先级都相同,则后一个数据不入队列被丢弃队列存储的数据内容是一个整数。

输入描述:
一组待存入队列的数据 (包含内容和优先级)

输出描述:
队列的数据内容(优先级信息输出时不再体现)

🎯 解题思路

可以使用优先级队列来实现,优先级队列中的元素会按照元素的优先级进行排序,优先级高的元素会被先出队列。如果两个元素优先级相同,则先进先出的原则决定元素出队列的顺序。

具体实现步骤:

  1. 定义一个优先级队列,元素类型为二元组,第一个元素为输入数据,第二个元素为优先级。
  2. 读入每个数据,将其作为一个二元组放入优先级队列中。
  3. 遍历优先级队列,逐个出队列并输出队列元素的第一个元素。

📙 Python代码实现

import queue# 定义优先级队列
pq = queue.PriorityQueue()# 读入每个数据并将其作为一个元素添加到优先级队列中
while True:try:data = input()# 输入数据格式为 "优先级 数据"priority, content = data.split()pq.put((int(priority), content))except:break# 遍历队列并输出队列元素的第二个元素
while not pq.empty():print(pq.get()[1])

📗 Java代码实现

import java.util.*;public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);// 定义一个优先级队列,元素类型为二元组PriorityQueue pq = new PriorityQueue < > ((a, b) - > {if (a.priority != b.priority) {return a.priority - b.priority;}return a.order - b.order;});// 读入每个数据并将其作为一个元素添加到优先级队列中int order = 0;while (sc.hasNext()) {int priority = sc.nextInt();String content = sc.next();pq.offer(new Pair(priority, content, order));order++;}// 遍历队列并输出队列元素的第二个元素while (!pq.isEmpty()) {System.out.println(pq.poll().content);}}
}// 定义一个二元组类表示队列的元素
class Pair {int priority; // 优先级String content; // 数据int order; // 加入队列的顺序public Pair(int priority, String content, int order) {this.priority = priority;this.content = content;this.order = order;}
}

📘 C语言代码实现

#
include# include// 定义一个二元组结构体表示队列的元素
typedef struct {int priority; // 优先级char * content; // 数据int order; // 加入队列的顺序
}
Pair;// 定义一个比较函数用于优先级队列的排序
int cmp(const void * a,const void * b) {Pair * pa = (Pair * ) a;Pair * pb = (Pair * ) b;if (pa - > priority != pb - > priority) {return pa - > priority - pb - > priority;}return pa - > order - pb - > order;
}int main() {int count = 0, capacity = 10;Pair * data = (Pair * ) malloc(capacity * sizeof(Pair));// 读入每个数据并将其作为一个元素添加到优先级队列中while (1) {int priority;char * content = (char * ) malloc(11 * sizeof(char));if (scanf("%d%s", & priority, content) != 2) {break;}if (count == capacity) {capacity *= 2;data = (Pair * ) realloc(data, capacity * sizeof(Pair));}data[count].priority = priority;data[count].content = content;data[count].order = count;count++;}// 对队列中的元素按照优先级和加入顺序排序qsort(data, count, sizeof(Pair), cmp);// 遍历队列并输出队列元素的第二个元素for (int i = 0; i < count; i++) {printf("%s\n", data[i].content);free(data[i].content);}free(data);return 0;
}

在这里插入图片描述

📭 本专栏包含了最新最全的2023年 华为OD机试真题,有详细的分析和解答。

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

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

相关文章

Windows进程管理

一、实验目的 &#xff08;1&#xff09;学会使用 VC 编写基本的 Win32 Consol Application&#xff08;控制台应用程序)。 &#xff08;2&#xff09;通过创建进程、观察正在运行的进程和终止进程的程序设计和调试操作&#xff0c;进一步熟悉操作系统的进程概念&#xff0c;…

Python Supervisord 进程管理工具

Supervisord&#xff0c;用Python实现的一款非常实用的进程管理工具&#xff0c;在批量服务化管理时特别有效。 环境centospython2.6.6 安装 wget http://pypi.python.org/packages/source/s/supervisor/supervisor-3.0a10.tar.gztar zxvf supervisor-3.0a10.tar.gzcd superv…

Linux 进程管理

介绍一些 Linux 所提供的工具来进行进程的查看与控制&#xff0c;掌握这些工具让我们能在某些进程出现异常的时候及时查看相关的指标&#xff0c;从而解决问题。 一、进程查看 top:实时的查看进程的状态ps:静态查看当前的进程信息pstree:查看当前活跃进程的属性结构 1.1 top工…

Python实现的进程管理神器——Supervisor

文章目录 常用命令简介安装创建配置文件开机自启初试Web 界面配置文件子进程配置模板可用变量supervisorctl 命令Supervisor 组件卸载遇到的坑参考文献 常用命令 修改配置并重启子进程 vim /etc/supervisor/conf.d/xxx.conf supervisorctl reread supervisorctl update super…

Supervisor后台进程管理工具

Supervisor后台进程管理工具安装配置 一、安装及配置 1、Python liunx自带有了不需要安装&#xff08;没有的话需要安装&#xff09; 2、easy_install是setuptools包里带的一个命令 wget--no-check-certificate https://bootstrap.pypa.io/ez_setup.py -O - | sudo python 3、安…

Linux运维工具Supervisor(进程管理工具)

文章目录 一、介绍二、自带Web管理程序三、安装1、安装2、源码安装3、yum安装 四、配置文件五、启动六、设置开机启动七、查看 supervisord 是否在运行八、supervisorctl管理命令九、配置文件说明十、ini配置文件 举例说明十一、开启web页面管理程序十二、解决“unix:///tmp/su…

【Supervisor】Python 进程管理工具

Supervisor的安装配置与使用 一、简介 【1】Supervisor是Python开发的进程管理工具&#xff08;Client/Server系统&#xff09;&#xff0c;可以管理和监控Unix&#xff0c;Linux&#xff0c;Mac OS X 系统上的进程&#xff0c;无法运行在Windows上 【2】Supervisor官方版目前只…

Python supervisor 强大的进程管理工具

一、问题背景 1、背景 如何才能让一个进程摆脱终端&#xff0c;获得相对较长的生命周期&#xff1f; 2、后台(守护)、前台进程 什么是守护进程&#xff1f;通俗点讲就是后台跑着的进程&#xff0c;不会因为你关了终端服务就会随之停止&#xff0c;直到你把计算机的电源关闭…

进程管理工具supervisor的使用、常见报错问题处理

进程管理工具supervisor的使用、常见报错问题处理 1 安装2 简介2.1 supservisor自身提供三个命令&#xff1a;2.1.1 supervisorctl2.1.2 supervisord2.1.3 echo_supervisord_conf 2.2 配置文件2.3 重要事项2.4 查看supervisor的log日志 3 配置3.1 修改配置文件3.2 加载配置文件…

进程管理工具——Supervisord简介及安装

一、简介 Supervisor 是一个用 Python 写的进程管理工具&#xff0c;可以很方便的用来在 UNIX-like 系统&#xff08;不支持 Windows&#xff09;下启动、重启&#xff08;自动重启程序&#xff09;、关闭进程&#xff08;不仅仅是 Python 进程&#xff09; Supervisor 是一个 …

Supervisor进程管理详解

文章目录 1. supervisor简介2. supervisor安装2.1 安装方式2.2 验证 3. supervisor配置文件3.1 主配置文件3.2 子配置文件(program 配置)3.2.1 详细配置3.2.2 公司配置 4. 进程管理命令5. web管理&#xff08;不常用&#xff09;6. Supervisor配置systemctl服务7. Supervisor管…

Linux 中进程管理工具汇总

如果我们的Linux系统整个系统资源快要被耗尽时&#xff0c;我们是否能够找出那个最消耗系统资源的进程&#xff0c;然后删除该进程&#xff0c;让系统恢复正常呢&#xff0c;或者由于某个程序存在BUG&#xff0c;导致产生一系列的问题&#xff0c;有如何查找它并结束进程&#…

Supervisor安装与配置(Linux/Unix进程管理工具)

原文链接&#xff1a;http://blog.csdn.net/xyang81/article/details/51555473 Supervisor&#xff08;http://supervisord.org/&#xff09;是用Python开发的一个client/server服务&#xff0c;是Linux/Unix系统下的一个进程管理工具&#xff0c;不支持Windows系统。它可以很…

linux进程管理工具:supervisor

各种各样的程序运行情况中&#xff0c;或多或少都会有一些服务是用脚本跑起来的&#xff0c;我们通常的做法一般都是让其在后台运行&#xff0c;例如使用nohup&#xff0c;&等命令。 而这样的方法并不十分可靠&#xff0c;所以在这里推荐一个非常好用的进程管理工具&#x…

进程管理工具Supervisor

简介 Supervisor是一个客户端/服务器系统&#xff0c;允许用户在类UNIX操作系统上控制许多进程。它是基于python语言开发一个进程管理工具。 Supervisor的服务器端称为supervisord&#xff0c;主要负责在启动自身时启动管理的子进程&#xff0c;响应客户端的命令&#xff0c;重…

Supervisor 进程管理

一、简介 supervisor 是一个Python开发的、通用的进程管理程序。当程序中断时&#xff0c;supervisor能自动重启它&#xff0c;不再需要程序员或系统管理员自己编写代码来控制。 supervisor要求管理程序是非daemon程序&#xff0c;supervisor会把程序转成daemon程序&#xff0…

电脑技巧:进程管理工具Process Explorer介绍

目录 1、介绍 2、常用功能介绍 2.1 替代微软自带的任务管理器 2.2 查看当前系统中运行的进程 2.3 查看进程的详细信息 2.4 检索进程 2.5 监控操作系统的性能指标 2.6 获取Dump文件 2.7 进程操作功能 今天给大家推荐一款非常强大的进程管理工具Process Explorer&#xff0c;感兴…

进程管理工具

目录 一、进程管理工具(Supervisor) 简介 二、Supervisor安装与配置 介绍Supervisor 一、进程管理工具(Supervisor) 简介 Supervisor是用Python开发的一个client/server服务&#xff0c;是Linux/Unix系统下的一个进程管理工具&#xff0c;不支持Windows系统。它可以很方便的…

QLoRA:量化 LLM 的高效微调

此 repo 支持论文“QLoRA&#xff1a;量化 LLM 的高效微调”&#xff0c;旨在使对 LLM 研究的访问民主化。 QLoRA 使用bitsandbytes进行量化&#xff0c;并与 Hugging Face 的PEFT和transformers库集成。QLoRA 由华盛顿大学 UW NLP 小组的成员开发。 概述 我们介绍了 QLoRA&…

访问学者申请中4个难点解析

近年来&#xff0c;越来越多的学者希望通过申请成为访问学者来扩展他们的研究领域和学术交流。然而&#xff0c;访问学者申请过程中存在一些难点&#xff0c;下面知识人网来解析其中的4个难点。 首先&#xff0c;第一个难点是选择适合的研究机构。访问学者需要仔细考虑自己的研…