Ver Mensaje Individual
  #1 (permalink)  
Antiguo 29/08/2008, 16:48
pumajavi
 
Fecha de Ingreso: agosto-2008
Mensajes: 2
Antigüedad: 16 años, 4 meses
Puntos: 0
Problema con skip list(lista de saltos)

Quisiera q me ayudaran con esto, tengo esta lista de saltos y queria agregarle el metodo toString() y la verdad q me complique mal!asi q ni lo hice. Si alguien me ayuda voy a estar muy agradecido!

Código:
import java.util.Random;

public class IntSkipList
{
	private int maxLevel;
	private IntSkipListNode[] root;
	private int [] powers;
	private Random rd=new Random();
	
	IntSkipList()
	{
		this(4);
	}
	
	IntSkipList(int i)
	{
		maxLevel=i;
		root=new IntSkipListNode[maxLevel];
		powers=new int[maxLevel];
		for(int j=0;j<maxLevel;j++)
			root[j]=null;
		choosePowers();
	}
	
	public boolean isEmpty()
	{
		return root[0]==null;
	}
	
	public void choosePowers()
	{
		powers[maxLevel-1]=(2<<(maxLevel-1))-1;
		for(int i=maxLevel-2,j=0;i>=0;i--,j++)
		{
			powers[i]=powers[i+1]-(2<<j);
		}
	}
	
	public int chooseLevel()
	{
		int i,r=Math.abs(rd.nextInt())%powers[maxLevel -1]+1;
		for(i=1;i<maxLevel;i++)
			if(r<powers[i])
				return i-1;
		return i-1;
	}
	
	public Comparable SkipListInSearch(Comparable key)
	{
		int lvl;
		IntSkipListNode prev,curr;
		for(lvl=maxLevel-1;lvl<=0&&root[lvl]==null;lvl--);
		prev=curr=root[lvl];
			while(true)
			{
				if(key.compareTo(curr.key)==0)
					return curr.key;
				else
					if(key.compareTo(curr.key)<0)
					{
						if(lvl==0)
							return 0;
						else
							if(curr==root[lvl])
								curr=root[--lvl];
							else
								curr=prev.next[--lvl];
					}
				else
				{
					prev=curr;
					if(curr.next[lvl]!=null)
					{
						curr=curr.next[lvl];
					}
					else
					{
						for(lvl--;lvl>=0&&curr.next[lvl]==null;lvl--);
						if(lvl>=0)
							curr=curr.next[lvl];
						else
							return 0;
					}
				}
			}
	}
	
	public void SkipListInsert(Comparable key)
	{
		IntSkipListNode[] curr=new IntSkipListNode[maxLevel];
		IntSkipListNode[] prev=new IntSkipListNode[maxLevel];
		IntSkipListNode newNode;
		int lvl,i;
		curr[maxLevel-1]=root[maxLevel-1];
		prev[maxLevel-1]=null;
		for(lvl=maxLevel-1;lvl>=0;lvl--)
		{
			while(curr[lvl]!=null&&curr[lvl].key.compareTo(key)<0)
			{
				prev[lvl]=curr[lvl];
				curr[lvl]=curr[lvl].next[lvl];
			}
			if(curr[lvl]!=null && curr[lvl].key==key)
				return;
			if(lvl>0)
				if(prev[lvl]==null)
				{
					curr[lvl-1]=root[lvl-1];
					prev[lvl-1]=null;
				}
				else
				{
					curr[lvl-1]=prev[lvl].next[lvl-1];
					prev[lvl-1]=prev[lvl];
				}
		}
		lvl=chooseLevel();
		
		newNode=new IntSkipListNode(key,lvl+1);
		for(i=0;i<=lvl;i++)
		{
			newNode.next[i]=curr[i];
			if(prev[i]==null)
				root[i]=newNode;
			else
				prev[i].next[i]=newNode;
		}
	}
}