- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我相信我刚刚正确完成了以下作业:
Implement a heap based priority queue class using the vector representation, containing characters.
我的程序已编译,并且在执行剩余任务时实现了所有所需的输出。我的问题是我是否真正正确地实现了堆。我的老师确定了基于堆的队列的三个关键方法:downheap、upheap 和 extractMin。
public static void upheap(int j)
{
int p = parent(j);
if(heap.get(j) < heap.get(p)) { swap(j,p); }
if (j == 0) return;
upheap(p);
}
public static char extractRoot()
{
if (heap.size() == 0)
return 0;
char root = heap.get(0);
heap.set(0,heap.get(heap.size() - 1));
heap.remove(heap.size() - 1);
downheap(0);
return root;
}
public static void downheap(int j)
{
if(hasLeft(j))
{
int smallerIndex = left(j);
if(hasRight(j) && heap.get(right(j)) < heap.get(left(j)))
smallerIndex = right(j);
if(heap.get(j) > heap.get(smallerIndex))
{
swap(j, smallerIndex);
}
upheap(j);
downheap(smallerIndex);
}
}
但是,我觉得我的 downheap 函数只是依赖于 upheap,实际上完全没有必要。我有这个功能:
public static void add(char c)
{
heap.add(c);
upheap(heap.size() - 1);
}
(其中堆是一个 ArrayList),并且会自动确保每个新条目都遵循堆顺序属性。我实际上从来没有使用 downheap 来对任何东西进行排序 - 那么将它保留在类中还有什么意义吗?我什么时候使用它?
如果有人想查看类中的其余方法,我将发布
最佳答案
实际上,您可以在 downheap() 方法中删除对 upheap() 的调用。如您所知,优先级队列堆中的根是最高优先级元素。仅当最高优先级元素被删除时,即根元素与最后一个元素交换时,downheap 方法才会出现。在您的情况下是 extractRoot() 方法。一旦您 extractRoot() ,堆中的所有其他元素都将满足堆属性,除了 root 上的元素。此外,当您向下移动根元素时,您正在与较小的值进行交换,即 swap(j, lesserIndex)。因此,在使用 downheap() 的情况下,永远不会需要将元素向上移动到堆上。
回答你的问题,当你调用add()时downHeap()是没用的,但当你调用extractMin()时downheap()是必要的。
关于java - 我是否正确实现了基于堆的优先级队列?下堆有必要吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33361489/
我正在使用 this solution在二进制矩阵中找到与图像边界对齐的矩形。假设现在我想找到一个不与图像边框对齐的矩形,并且我不知道它的方向;找到它的最快方法是什么? 为了示例,让我们寻找一个仅包含
else: 行在这个 Python 程序中是否正确/必要? from random import randrange for n in range(10): r = randrange(0,1
在 TDPL 7.1.5.1 中讨论了将 Widget w2 分配给 w1 并且作者指出“将 w2 逐个字段分配给 w1 会将 w2.array 分配给 w1.array——一个简单的数组边界分配,而
我是一名优秀的程序员,十分优秀!