jons-mark 2015-07-22 13:06 采纳率: 14.3%
浏览 1496

HDU 1509 Windows Message Queue

自己测试总刚觉没错,求高手帮忙,不知道哪错了,总wa。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

  • 写回答

3条回答

  • jons-mark 2015-07-22 13:06
    关注

    import java.util.Comparator;
    import java.util.PriorityQueue;
    import java.util.Scanner;

    class Nod {

    String name;
    int val, pri;
    
    public Nod(String name, int val, int pri) {
        this.name = name;
        this.val = val;
        this.pri = pri;
    }
    
    public String getName() {
        return name;
    }
    
    public void setName(String name) {
        this.name = name;
    }
    
    public int getVal() {
        return val;
    }
    
    public void setVal(int val) {
        this.val = val;
    }
    
    public int getPri() {
        return pri;
    }
    
    public void setPri(int pri) {
        this.pri = pri;
    }
    

    }

    public class Main4 {

    public static void main(String[] args) {
        Comparator<Nod> con = new Comparator<Nod>() {
            @Override
            public int compare(Nod a, Nod b) {
                int n1 = a.getPri();
                int n2 = b.getPri();
                int m1 = a.getVal();
                int m2 = b.getVal();
                if (n1 > n2) {
                    return 1;
                } else if (n1 < n2) {
                    return -1;
                } else {
                    return 0;
                }
            }
        };
        PriorityQueue<Nod> q = new PriorityQueue<Nod>(con);
        Scanner sc = new Scanner(System.in);
        while (sc.hasNext()) {
            String str = sc.next();
            if (str.equals("GET")) {
                if (q.isEmpty()) {
                    System.out.println("EMPTY QUEUE!");
                } else {
                    Nod n;
                    n = q.poll();
                    System.out.println(n.getName() + " " + n.getVal());
                }
            } else {
                String name = sc.next();
                int v = sc.nextInt();
                int p = sc.nextInt();
                Nod n = new Nod(name, v, p);
                q.add(n);
            }
        }
    }
    

    }

    
    
    评论

报告相同问题?

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘