因此,我正在尝试实现FastDefaultList类,该类基本上是一个跳过列表,它表示索引为0、1、2、3,…,∞的无限列表。首先,此列表中的每个值都被分配为默认值null。否则,此类的行为类似于List;它具有add(i,x),remove(i),set(i,x)和get(i),其行为与列表中的相同方法相同。这些操作中的每一个都应在O(log n)时间中运行。我的很多清单代码来自:
https://opendatastructures.org/odsjava/4_2_SkiplistSSet_Efficient_.html
我想我大部分都可以正常工作,但是我正在尝试修复get()和set()方法。每当我尝试编译程序时,都会出现错误:
错误:没有找到适合的方法add(int,FastDefaultList.Node,int)add(i,node,0);
我不确定为什么。任何帮助,将不胜感激。
package comp;
import java.lang.reflect.Array;
import java.lang.IllegalStateException;
import java.util.AbstractList;
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import java.util.NoSuchElementException;
import java.util.Random;
public class FastDefaultList<T> extends AbstractList<T> {
class Node {
T x;
Node[] next;
int[] length;
@SuppressWarnings("unchecked")
public Node(T ix, int h) {
x = ix;
next = (Node[])Array.newInstance(Node.class, h+1);
length = new int[h+1];
}
public int height() {
return next.length - 1;
}
}
/**
* This node sits on the left side of the skiplist
*/
protected Node sentinel;
/**
* The maximum height of any element
*/
int h;
/**
* The number of elements stored in the skiplist
*/
int n; // Hint: You don't need this anymore!
/**
* A source of random numbers
*/
Random rand;
public FastDefaultList() {
n = 0;
sentinel = new Node(null, 32);
h = 0;
rand = new Random(0);
}
/**
* Represents a node/index Pair
*/
protected class Pair {
Node u;
int j;
Pair(Node u, int j) {
this.u = u;
this.j = j;
}
}
protected Pair findPred(int i) {
Node u = sentinel;
int r = h;
int j = -1; // index of the current node in list 0
while (r >= 0) {
while (u.next[r] != null && j + u.length[r] < i) {
j += u.length[r];
u = u.next[r];
}
r--;
}
return new Pair(u, j);
}
public T get(int i) {
if (i < 0 || i > size()-1) throw new IndexOutOfBoundsException();
Pair n = findPred(i);
if(n.u.next[0] != null && n.j + n.u.length[0] == i){ return n.u.next[0].x; }
return null;
}
public T set(int i, T x) {
if (i < 0 || i > size()-1) throw new IndexOutOfBoundsException();
Pair n = findPred(i);
if (n.u.next[0] != null && n.j + n.u.length[0] == i) {
Node u = n.u.next[0];
T y = u.x;
u.x = x;
return y;
}
else{
Node node = new Node(x, pickHeight());
if(node.height() > h){ h = node.height(); }
add(i, node, 0);
}
return null;
}
/**
* Insert a new node into the skiplist
* @return the node u that precedes v in the skiplist
*/
protected Node add(int i, Node w) {
Node u = sentinel;
int k = w.height();
int r = h;
int j = -1; // index of u
while (r >= 0) {
while (u.next[r] != null && j+u.length[r] < i) {
j += u.length[r];
u = u.next[r];
}
u.length[r]++; // accounts for new node in list 0
if (r <= k) {
w.next[r] = u.next[r];
u.next[r] = w;
w.length[r] = u.length[r] - (i - j);
u.length[r] = i - j;
}
r--;
}
n++;
return u;
}
/**
* Simulate repeatedly tossing a coin until it comes up tails.
* Note, this code will never generate a height greater than 32
* @return the number of coin tosses - 1
*/
protected int pickHeight() {
int z = rand.nextInt();
int k = 0;
int m = 1;
while ((z & m) != 0) {
k++;
m <<= 1;
}
return k;
}
public void add(int i, T x) {
if (i < 0 || i > size()-1) throw new IndexOutOfBoundsException();
Node w = new Node(x, pickHeight());
if (w.height() > h)
h = w.height();
add(i, w);
}
public T remove(int i) {
if (i < 0 || i > size()-1) throw new IndexOutOfBoundsException();
T x = null;
Node u = sentinel;
int r = h;
int j = -1; // index of node u
while (r >= 0) {
while (u.next[r] != null && j+u.length[r] < i) {
j += u.length[r];
u = u.next[r];
}
u.length[r]--; // for the node we are removing
if (j + u.length[r] + 1 == i && u.next[r] != null) {
x = u.next[r].x;
u.length[r] += u.next[r].length[r];
u.next[r] = u.next[r].next[r];
if (u == sentinel && u.next[r] == null)
h--;
}
r--;
}
n--;
return x;
}
public int size() {
return Integer.MAX_VALUE;
}
public String toString() {
StringBuilder sb = new StringBuilder();
int i = -1;
Node u = sentinel;
while (u.next[0] != null) {
i += u.length[0];
u = u.next[0];
sb.append(" " + i + "=>" + u.x);
}
return sb.toString();
}
public static void main(String[] args) {
}
}
问题来源:Stack Overflow
您的添加功能正在接受2个参数
protected Node add(int i, Node w)
但是您用3个参数来称呼它-
这里:
if(node.height() > h){ h = node.height(); }
add(i, node, 0);
``
回答来源:Stack Overflow
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。