Очередь приоритетов Java, которая расширяется сопоставимо? - PullRequest
0 голосов
/ 16 марта 2019

Я работаю над заданием класса, и я не совсем понимаю, как использовать компаратор в том смысле, в котором оно задано.

Назначение гласит:

"Завершить класс очереди приоритетов

  1. Ваша очередь приоритетов должна использовать анонимную функцию для определения приоритета
  2. Она должнапринять интерфейс Function в качестве параметра для конструктора
  3. У вас все еще должен быть конструктор по умолчанию - и если функция не предоставлена, используйте функцию CompareTo класса "

Этокласс, над которым я работаю ...

public class PriorityQueue <Item extends Comparable<Item>> {

    public PriorityQueue()
    {

    }
    public PriorityQueue(Comparator<Item> compare )
    {

    }  

    private int size = 0;
    private Node<Item> head = null;
    private Comparator<Item> compare ;

    private static class Node<Item>
    {
       private Item data;
       private Node<Item> next;


    public Node(Item data, Node<Item> next)
       {
          this.data = data;
          this.next = next;
       }       
       public Node(Item data)
       {
          this.data = data;
          this.next = null;
       }       
       public Node()
       {
          this.data = null;
          this.next = null;
       }
    }

    @Override
    public int size() {
        return size;
    }

    @Override
    public Item dequeue() {
        // TODO Auto-generated method stub
        return null;
    }

    @Override
    public void enqueue(Item item) {
        Node<Item> curr = head;
        Node<Item> prev = curr;

        if (isEmpty())
        {
            head = new Node<Item>(item,null);
        }
        else
        {
            while (curr != null)
            {
                prev = curr;
                curr = curr.next;
            }

            prev.next = new Node<Item>(item, curr);
        }
        size++;
    }

    @Override
    public boolean isEmpty() {
        return size == 0;
    }

    @Override
    public void printQueue() {
        Node<Item> curr = head;

        while (curr != null)
        {
            System.out.println(curr.data);
            curr = curr.next;
        }

    }
}

Это класс процесса, который будет содержать очередь ...

public class Process implements Comparable<Process> {

    private ProcessPriorty priority;
        private String name;

    public Process(ProcessPriorty priority, String name) {
        super();
        this.priority = priority;
        this.name = name;
    }

    public void setPriority(ProcessPriorty priority) {
        this.priority = priority;
    }

    @Override
    public String toString() {
        return name + "... Priority = " + priority + ".";
    }

    public String getName() {
        return name;
    }

    public ProcessPriorty getPriority() {
        return priority;
    }

    @Override
    public int compareTo(Process other) {

        if(other == null)
        {
            return  1;
        }
        return this.priority.compareTo(other.priority) ;
    }
}

Я понимаю концепцию очереди и дажезакодировал метод enqueue для работы в качестве простой очереди, которая вставляет элементы по мере их поступления. Я сталкиваюсь с проблемой сравнения узлов в этом методе для сортировки списка по приоритету при вставке.Я верю, что это связано с этими тремя направлениями работы.Итак, что я должен делать с конструкторами, переменной Comparator, и как мне сделать его по умолчанию для сравнения?

1 Ответ

0 голосов
/ 16 марта 2019

Ну, так как у вас есть ссылка на главу очереди, оттуда все довольно просто.У вас есть 2 дела -

  1. compare != null
  2. compare == null

    • В первом случае вы заинтересованы в Компаратор :: CompareTo .Из определения приоритетной очереди все, что вам нужно сделать, - это пройти очередь, начиная с головы, и как только item в enqueue(Item item) будет больше, чем текущий element в обходе, вы вставите itemдо element.Вы будете использовать compare.compareTo(item, element) для определения их порядка.

    • Во втором случае вы просто будете использовать item.compareTo(element), чтобы сделать вышеупомянутое сравнение, обход и вставка будутто же самое.

...