gpt4 book ai didi

java - 如何直接访问最小堆中的对象,java

转载 作者:太空宇宙 更新时间:2023-11-04 13:59:34 24 4
gpt4 key购买 nike

public class Link {
public int weight;
public int loc;
public Link next;
public boolean visited;
public Link parent;

public Link(int d, int loc){
this.weight = d;
this.loc = loc;
this.visited = false;
}
public Link(Link p, int d, int loc){
this.parent = p;
this.weight = d;
this.loc = loc;
}

public void printLink(){
System.out.println(weight);
}
}
<小时/>
class LinkList{


public Link first;

public LinkList(){
first = null;
}
public void add(int d, int loc){
Link link = new Link(d, loc);
if (first == null){
first = link;
}
else{
Link curr = first;
while (curr.next!=null){
curr = curr.next;
}
curr.next = link;
}

}
public void printList(){
Link currentLink = first;
System.out.println("List: ");
while(currentLink != null) {
currentLink.printLink();
currentLink = currentLink.next;
}
System.out.println("");
}
public boolean isEmpty(){
return first == null;
}
public Link delete(){
Link temp = first;
first = first.next;
return temp;
}

}
<小时/>
 public class MinHeap {
public Link[] Heap;
public int size;
public int maxsize;

private static final int FRONT = 0;

public MinHeap(int maxsize, Link x)
{
this.maxsize = maxsize;
this.size = 0;
Heap = new Link[this.maxsize + 1];
Heap[0] = x;
}

private int parent(int pos)
{
return pos / 2;
}

private int leftChild(int pos)
{
return (2 * pos);
}

private int rightChild(int pos)
{
return (2 * pos) + 1;
}

private boolean isLeaf(int pos)
{
if (pos >= (size / 2) && pos <= size)
{
return true;
}
return false;
}

private void swap(int fpos, int spos)
{
Link tmp;
tmp = Heap[fpos];
Heap[fpos] = Heap[spos];
Heap[spos] = tmp;
}

private void minHeapify(int pos)
{
if (!isLeaf(pos))
{
if ( Heap[pos].weight > Heap[leftChild(pos)].weight || Heap[pos].weight > Heap[rightChild(pos)].weight)
{
if (Heap[leftChild(pos)].weight < Heap[rightChild(pos)].weight)
{
swap(pos, leftChild(pos));
minHeapify(leftChild(pos));
}else
{
swap(pos, rightChild(pos));
minHeapify(rightChild(pos));
}
}
}
}

public void add(Link element)
{
Heap[++size] = element;
int current = size;

while (Heap[current].weight < Heap[parent(current)].weight)
{
swap(current,parent(current));
current = parent(current);
}
}

public void print()
{
for (int i = 1; i <= size / 2; i++ )
{
System.out.print(" PARENT : " + Heap[i] + " LEFT CHILD : " + Heap[2*i]
+ " RIGHT CHILD :" + Heap[2 * i + 1]);
System.out.println();
}
}

public void minHeap()
{
for (int pos = (size / 2); pos >= 1 ; pos--)
{
minHeapify(pos);
}
}
public boolean inQ(Link d){
int x = d.weight;
for (int i = 0; i<size;i++){
if (Heap[i].weight == x){
return true;
}
}
return false;
}

public Link remove()
{
Link popped = Heap[FRONT];
Heap[FRONT] = Heap[size--];
minHeapify(FRONT);
return popped;
}
}

我这里有一个最小堆类,它根据权重属性存储 Link 对象。我的目标是能够直接访问和更改存储在最小堆中的对象的属性。我需要能够仅根据“loc”属性访问这些对象。
例如,我可能想要访问 loc 值为 6 的 Link 对象并更改其父属性或权重属性;但是我只知道它是访问时的 loc 属性值。
我的理解是我应该使用指向这些对象的指针数组,但我不确定如何实现它。

谢谢!

最佳答案

根据您的代码,每个链接都知道其父级以及列表中的下一个元素。

您应该遵循以下算法并更新必填字段。

  1. 首先将链接对象和 loc 值传递给更新权重/父级的方法。您可以编写两种方法,一种用于更新权重,另一种用于更新权重,或者您可以使用一种方法并使用一个标志来隔离 Activity 。

  2. 如果你想更新权重,很简单。

  3. 如果您想更新父对象,则必须将新的父对象也传递给该方法,因为您还应该更新父对象的下一个对象,但请确保正确处理代码,因为您可能会丢失父对象的现有下一个对象。

当您传递实际对象时,jvm 会保留相同的对象。确保不要传递列表权重/父级的值。

关于java - 如何直接访问最小堆中的对象,java,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29442701/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com