百度&必应权4, 日IP1w+ 查看详情
自助收录

2023年华为OD机考真题:打印文件

算法刷题2年前 (2023)更新 江南白衣
701 0 0
2023年华为OD机考真题:打印文件

全网最全面的华为OD机试真题汇总,100%原题题库,不需要开会员即可查看全部内容,更多考题请查看真题库。

真题库:https://www.yuque.com/codernav.com/od

题目:打印文件
时间限制:1s 空间限制:256MB 限定语言:不限
题目描述:
有5台打印机打印文件,每台打印机有自己的待打印队列。因为打印的文件内容有轻重缓急之分,所以队列中的文件有1~10不同的优先级,其中数字越大优先级越高。打印机会从自己的待打印队列中选择优先级最高的文件来打印。如果存在两个优先级一样的文件,则选择最早进入队列的那个文件。
现在请你来模拟这5台打印机的打印过程。
输入描述:
每个输入包含1个测试用例,每个测试用例第1行给出发生事件的数量 N (0 < N < 1000)。
接下来有 N 行,分别表示发生的事件。
共有如下两种事件:
"IN P NUM",表示有一个拥有优先级 NUM 的文件放到了打印机 P 的待打印队列中。(0 < P <= 5, 0 < NUM <= 10);
"OUT P",表示打印机 P 进行了一次文件打印,同时该文件从待打印队列中取出。(0 < P <= 5)。
输出描述:
对于每个测试用例,每次"OUT P"事件,请在一行中输出文件的编号。如果此时没有文件可以打印,请输出"NULL"。
文件的编号定义为:"IN P NUM"事件发生第 X 次,此处待打印文件的编号为 X。编号从1开始。
示例1
输入:
7
IN 1 1
IN 1 2
IN 1 3
IN 2 1
OUT 1
OUT 2
OUT 2
输出:
3
4
NULL
示例2
输入:
5
IN 1 1
IN 1 3
IN 1 1
IN 1 3
OUT 1
输出:
2
解题思路:
使用map来放置打印任务
Key:打印机的编号
Value:type:集合 优先级和打印编号(就是第几次打印)
碰到IN,将数据存入map
碰到OUT,则判断此打印机,且此打印机是否存在打印任务,存在则求出此打印机的打印任务集合,并将集合按照优先级进行升序排序,取出第一个元素,则为此次打印任务,并将此次任务移除;如不存在此打印机或者打印任务不存在,则输出NLL

代码实现一:

package com.codernav.demo.hwod.exam;

import java.util.*;

/**
 * @title 打印文件
 * @Description 有5台打印机打印文件,每台打印机有自己的待打印队列。
 * 因为打印的文件内容有轻重缓急之分,所以队列中的文件有1~10不同的优先级,其中数字越大优先级越高。
 * 打印机会从自己的待打印队列中选择优先级最高的文件来打印。如果存在两个优先级一样的文件,则选择最早进入队列的那个文件。
 * @Author 开发者导航
 * @website https://codernav.com
 * @date 2023/5/13
 */
public class Main {

    public static void main(String[] args) {

        Scanner sc = new Scanner(System.in);

        int n = sc.nextInt();
        sc.nextLine();

        /**
         * 将打印任务放在map对象中
         * key: String 打印机编号
         * value: List<int[]>数组集合
         * int[0]: 优先级
         * int[1]: 打印编号
         */
        Map<String, List<int[]>> map = new HashMap<>();
        int count = 0;  //打印编号
        for (int i = 0; i < n; i++) {
            String[] strs = sc.nextLine().split(" ");
            if (strs[0].equals("IN")) {   //打印任务
                int[] inInts = new int[2];
                inInts[0] = Integer.parseInt(strs[2]);  //优先级
                inInts[1] = ++count;   //打印编号递增
                List<int[]> inList = new ArrayList<>();
                if (map.containsKey(strs[1])) {
                    inList = map.get(strs[1]);
                    inList.add(inInts);
                } else {
                    inList.add(inInts);
                }
                map.put(strs[1], inList);
            } else if (strs[0].equals("OUT")) {    //进行打印
                if (!map.containsKey(strs[1])) {  //打印机不存在
                    System.out.println("NULL");
                    continue;
                }
                List<int[]> outList = map.get(strs[1]);     //获取strs[1]打印机的所有任务
                if (outList.size() == 0) {    //打印机没有任务
                    System.out.println("NULL");
                } else {
                    outList.sort((a, b) -> {     //根据打印优先级排序
                        return b[0] - a[0];
                    });
                    System.out.println(outList.get(0)[1]);
                    outList.remove(0);
                }
            }
        }
    }
}

代码实现二:

package com.codernav.demo.hwod.exam;

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

/**
 * @title 打印文件
 * @Description 有5台打印机打印文件,每台打印机有自己的待打印队列。
 * 因为打印的文件内容有轻重缓急之分,所以队列中的文件有1~10不同的优先级,其中数字越大优先级越高。
 * 打印机会从自己的待打印队列中选择优先级最高的文件来打印。如果存在两个优先级一样的文件,则选择最早进入队列的那个文件。
 * @Author 开发者导航
 * @website https://codernav.com
 * @date 2023/5/13
 */
public class Main {
    public static void main(String[] args) {
        List<List<File>> m = new ArrayList<>();
        for (int i = 0; i < 5; i++) {
            m.add(new ArrayList<>());
        }
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();
        int flag = 0;
        for (int i = 0; i <= n; i++) {
            String s = in.nextLine();
            String[] s1 = s.split(" ");
            String type = s1[0];

            if ("IN".equals(type)) {
                int p = Integer.parseInt(s1[1]);
                int num = Integer.parseInt(s1[2]);
                flag++;
                File file = new File(flag, num);
                List<File> files = m.get(p - 1);
                files.add(file);
            } else if ("OUT".equals(type)) {
                int p = Integer.parseInt(s1[1]);
                List<File> files = m.get(p - 1);
                if (files != null && files.size() > 0) {
                    files.sort((a, b) -> b.getWeight() - a.getWeight());
                    File file = files.get(0);
                    System.out.println(file.getIndex());
                    files.remove(0);
                } else {
                    System.out.println("NULL");
                }
            }
        }
    }
}

class File {
    private int index;
    private int weight;

    public File(int index, int weight) {
        this.index = index;
        this.weight = weight;
    }

    public int getIndex() {
        return index;
    }

    public void setIndex(int index) {
        this.index = index;
    }

    public int getWeight() {
        return weight;
    }

    public void setWeight(int weight) {
        this.weight = weight;
    }
}

 

© 版权声明
开发者导航

相关文章

开发者导航

暂无评论

暂无评论...