1. 考察双向链表
  2. import java.io.IOException;
    import java.io.InputStreamReader;
    import java.io.StreamTokenizer;
    import java.util.LinkedList; public class Main {
    @SuppressWarnings("uncheck")
    public static void main(String[] args) throws IOException {
    StreamTokenizer st = new StreamTokenizer(new InputStreamReader(System.in));
    int n, m, k, q;
    st.nextToken();
    n = (int) st.nval;
    st.nextToken();
    m = (int) st.nval;
    st.nextToken();
    k = (int) st.nval;
    st.nextToken();
    q = (int) st.nval; LinkedList<int[]>[] queue = new LinkedList[n];
    for (int i = 0; i < n; i++) {
    queue[i] = new LinkedList<>();
    }
    int[][] time = new int[k + 1][2];
    int[] cost = new int[k];
    for (int i = 0; i < k; i++) {
    st.nextToken();
    int v = (int) st.nval;
    cost[i] = v;
    if (i < m * n) {
    if (queue[i % n].isEmpty()) {
    queue[i % n].add(new int[]{i, 0, v});
    time[i + 1] = new int[]{0, v};
    continue;
    }
    int[] last = queue[i % n].getLast();
    int finishedtime = last[2];
    queue[i % n].add(new int[]{i, finishedtime, finishedtime + v});
    time[i + 1] = new int[]{finishedtime, finishedtime + v};
    } else {
    int min = 1000_000_00;
    int minindex = -1;
    for (int j = 0; j < n; j++) {
    int[] first = queue[j].peekFirst();
    if (min > first[2]) {
    min = first[2];
    minindex = j;
    }
    }
    int[] last = queue[minindex].getLast();
    int finishedtime = last[2]; queue[minindex].pollFirst();
    queue[minindex].add(new int[]{i, finishedtime, finishedtime + v}); time[i + 1] = new int[]{finishedtime, finishedtime + v};
    }
    } int max = 540;
    for (int i = 1; i <= q; i++) {
    st.nextToken();
    int index = (int) st.nval;
    if (time[index][0] < max) {
    System.out.println(format(time[index][1]));
    } else {
    System.out.println("Sorry");
    }
    }
    } public static String format(int time) {
    int x = time / 60 + 8;
    int y = time % 60; StringBuilder sb = new StringBuilder();
    if (x < 10) {
    sb.append("0").append(x);
    } else {
    sb.append(x);
    }
    sb.append(":");
    if (y < 10) {
    sb.append("0").append(y);
    } else {
    sb.append(y);
    }
    return sb.toString();
    }
    }

PAT甲级【1014 Waiting in Line】的更多相关文章

  1. PAT甲级1014. Waiting in Line

    PAT甲级1014. Waiting in Line 题意: 假设银行有N个窗口可以开放服务.窗前有一条黄线,将等候区分为两部分.客户要排队的规则是: 每个窗口前面的黄线内的空间足以包含与M个客户的一 ...

  2. PAT 甲级 1014 Waiting in Line (30 分)(queue的使用,模拟题,有个大坑)

    1014 Waiting in Line (30 分)   Suppose a bank has N windows open for service. There is a yellow line ...

  3. PAT A 1014. Waiting in Line (30)【队列模拟】

    题目:https://www.patest.cn/contests/pat-a-practise/1014 思路: 直接模拟类的题. 线内的各个窗口各为一个队,线外的为一个,按时间模拟出队.入队. 注 ...

  4. PAT甲级——A1014 Waiting in Line

    Suppose a bank has N windows open for service. There is a yellow line in front of the windows which ...

  5. PAT 1014 Waiting in Line (模拟)

    1014. Waiting in Line (30) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue Suppo ...

  6. 1014 Waiting in Line (30分)

    1014 Waiting in Line (30分)   Suppose a bank has N windows open for service. There is a yellow line i ...

  7. PTA (Advanced Level) 1014 Waiting in Line

    Waiting in Line Suppose a bank has N windows open for service. There is a yellow line in front of th ...

  8. 【PAT甲级】1014 Waiting in Line (30 分)(队列维护)

    题面: 输入四个正整数N,M,K,Q(N<=20,M<=10,K,Q<=1000),N为银行窗口数量,M为黄线内最大人数,K为需要服务的人数,Q为查询次数.输入K个正整数,分别代表每 ...

  9. PAT 1014. Waiting in Line

    Suppose a bank has N windows open for service.  There is a yellow line in front of the windows which ...

  10. PAT 1014 Waiting in Line (模拟)

    Suppose a bank has N windows open for service. There is a yellow line in front of the windows which ...

随机推荐

  1. clickhouse导入和导出

    一.连接clickhouse--客户端连接default库clickhouse-client -h localhost --port 9001 -u default --password 123456 ...

  2. Pandas日期时间格式化

    当进行数据分析时,我们会遇到很多带有日期.时间格式的数据集,在处理这些数据集时,可能会遇到日期格式不统一的问题,此时就需要对日期时间做统一的格式化处理.比如"Wednesday, June ...

  3. OAuth2 Authorization Server

    基于Spring Security 5 的 Authorization Server的写法 先看演示 pom.xml <?xml version="1.0" encoding ...

  4. 【leetcode】如何实现 regex 正则表达式引擎

    题目 给你一个字符串 s 和一个字符规律 p,请你来实现一个支持 '.' 和 '*' 的正则表达式匹配. '.' 匹配任意单个字符 '*' 匹配零个或多个前面的那一个元素 所谓匹配,是要涵盖 整个 字 ...

  5. adb查看和修改settings值

    初始化命令 对应USB连接的安卓设备 # 用help查看版本,位置和参数 >adb --help Android Debug Bridge version 1.0.41 Version 30.0 ...

  6. CSS font-weight

    主要理解UI给得英文名 对应得数值 字体粗细:'font-weight'属性名称: font-weight取值: normal | bold | bolder | lighter | 100 | 20 ...

  7. 使用`react-hooks写法`对`antd的Upload.Dragger上传组件`进行二次封装

    使用react-hooks写法对antd的Upload.Dragger上传组件进行二次封装 预期 对antd的Upload.Dragger组件进行二次封装,让它的使用方法和Upload.Dragger ...

  8. 工作中django的应用路径配置

    1.通常工作中都会把所有的应用放在一个主目录中 比如:主项目文件夹为luffyapi 在luffyapi下创建一个apps文件夹,用来存放所有的app应用 2.创建应用 先创建一个应用,需要cd到ap ...

  9. PrettyTable模块

    # 用来生成美观的ASCII格式的表格 pip install prettytable # 导入 from prettytable import PrettyTable # 使用 tb = pt.Pr ...

  10. 【LeetCode二叉树#06】获取二叉树的所有路径(分析递归中的回溯机制)

    二叉树所有路径 力扣题目链接(opens new window) 给定一个二叉树,返回所有从根节点到叶子节点的路径. 说明: 叶子节点是指没有子节点的节点. 示例: 思路 根据题意,每次遍历至子节点, ...