堆积为一般对象

时间:2012-11-09 06:11:18

标签: java coding-style

我正在编写一个Heap(Max-Heap,意思是max element is root)类,可用于“堆积”给定的一组对象。 我知道这个堆的一般结构以及各种算法。 现在对于一般对象,没有定义比较。所以我需要定义两个对象之间的比较。 我的问题是,是否应该在类堆或类Object中定义此比较函数?如果我在类Heap中定义它,那么对于我使用的每个数据结构,我需要重写比较函数,这是无效的。这是因为如果我稍微更改了Object,我可能最终会在很多地方更改比较。 那怎么处理呢? 谢谢。

 class Object{
     int value;
     Object (int a) {
         value=a;
     }

     boolean isLessThan(Object a, Object b){
         if (a.value<=b.value){
             return true;
         }
         else return false;
     }
 }

 class Heap{
     Object [] heap=new Object[1000];
     int size=0;
     Heap() {        
     }

     void HeapifyDownwards (int index){
         int left_child=2*index+1;
         int right_child=2*index+2;

         if (size>right_child){
             // both right and left child exist
             Object right= heap[right_child];
             Object left= heap[left_child];
             Object node = heap[index];

             if ((isLessThanEqualTo(right,node)) && (isLessThanEqualTo(left,node))){
                 return;
             }
         }
         else if (size==right_child){
             //only left child exists
         } 
         else {
             // no child exists
         }
     }
 }

2 个答案:

答案 0 :(得分:1)

这些事情在Java中处理的一般方式是:

  1. 限制存储在数据结构中的元素以实现Comparable
  2. 将比较器存储在堆对象中(在构造时设置)。
  3. 查看TreeSet class in the Java API的示例。

    请注意,由于Java是(大部分)静态类型语言,因此对这种数据结构使用泛型非常常见。它们可能值得学习,尽管我可以理解让堆类为特定类型的对象工作的愿望。

    另外,如果本练习的目的是学习如何工作,那么很好。如果您确实需要Java应用程序的优先级队列,那么Java已经有PriorityQueue类。

答案 1 :(得分:0)

确定! 解决方案是使用Comparable而不是Objects。 然后使用node.compareTo(右)(等)进行比较!

有关更多详细信息,请参阅此链接: Abstract Object Comparison in Java

public class Heap{
    Comparable [] heap=new Comparable[1000];
    int size=0;
    Heap() {        
    }
    public void HeapifyDownwards (int index){
        int left_child=2*index+1;
        int right_child=2*index+2;

        Comparable right= heap[right_child];
        Comparable left= heap[left_child];
        Comparable node = heap[index];

        if (size>right_child){
            // both right and left child exist
            if ((node.compareTo(right)>0) && (node.compareTo(left)>0)){
                return;
            }
            else if ((right.compareTo(node)>0) && (right.compareTo(left)>0)){
                Comparable temp=right;
                heap[right_child]=node;
                heap[index]=temp;
                HeapifyDownwards(right_child);
            }
            else if ((left.compareTo(node)>0) && (left.compareTo(right)>0)){
                Comparable temp=left;
                heap[left_child]=node;
                heap[index]=temp;
                HeapifyDownwards(left_child);
            }
        }
        else if (size==right_child){
            //only left child exists
            if (left.compareTo(node)>0){
                Comparable temp=left;
                heap[left_child]=node;
                heap[index]=temp;
                HeapifyDownwards(left_child);
            }
            else {return;}
        } 
        else {
            return;
        }
    }
    public void HeapifyUpwards (int index){
        int parent_index=(index-1)/2;

        Comparable parent= heap[parent_index];
        Comparable node = heap[index];

        if (node.compareTo(parent)>0){
            Comparable temp= parent;
            heap[parent_index]=node;
            heap[index]=temp;
            HeapifyUpwards(parent_index);
        }
        else{
            return;
        }
    }
    public void Insert (Comparable in){
        heap[size]=in;
        size++;
        HeapifyUpwards(size-1);
    }
    public Comparable Remove (){
        Comparable out=heap[0];
        heap[0]=heap[size-1];
        size--;
        HeapifyDownwards(0);
        return out;
    }
}


public class TestObject implements Comparable{
    int value;
    TestObject (int a) {
        value=a;
    }

    @Override
    public int compareTo (Object b){
         if (this.getClass() == b.getClass()){
            TestObject b_test = (TestObject) b;
            if (this.value<b_test.value){
                return -1;
            }
            else if(this.value==b_test.value){
                return 0;
            }
            else return 1;
         }
         else return -1;
    }

    public void Print (){
        System.out.println(value);
    }
}