java中的双链表

时间:2013-09-24 01:12:37

标签: java eclipse

我遇到了这些方法的问题。没有输出是正确的,我不确定我是否正确使用双链表。有人可以纠正或向我解释我做错了吗?

public class SlideList 
{

    private SlideNode head;
    private SlideNode tail;
    private SlideNode cursor;

    public SlideList()
    {
        head = null;
        tail = null;
        cursor = null;
    }
    public void editCurrentSlide(String text, int lineNum) throws IllegalArgumentException 
    {
        if(cursor==null||lineNum>5||lineNum<0)
            throw new IllegalArgumentException("Slide does not exist");
        cursor.getSlide().setData(text, lineNum);
    }
    public boolean jumpToPosition(int position)
    {
        if(position<0 || position>listLength())
            return false;
        resetCursor();
        for(int x=1;x<=position;x++)
        {
            cursor = cursor.getNext();
        }
        return true;
    }
    public void displayCurrentSlide() throws EmptyListException
    {
        if(cursor==null)
            throw new EmptyListException("There is no list");
        displaySlide(currentSlide());
    }
    public void displaySlides(int start, int end) throws IllegalArgumentException
    {
        int length = listLength();
        resetCursor();
        if(start<1)
            start=1;
        if(end>length)
            end = length;
        if(start>length||length==0)
            throw new IllegalArgumentException("There is no list");
        resetCursor();

        for(int i = 1; i < start; i++)//we can choose where to start the list with i
        {
            System.out.println("Inside loop1");
            cursor=cursor.getNext();

        }
        System.out.println("start: " + start + " end: " + end);
        for(int x = start; x<=end; x++)
        {

            System.out.println("Inside loop2");
            displaySlide(x);
            if(start<end)
                cursor = cursor.getNext();

        }
        //cursor = cursor.getPrev();


    }
    public void displaySlide(int x)
    {
        System.out.print("******************************");
        System.out.print(" " + x + " ");
        System.out.print("******************************\n\n");
        System.out.print(cursor.getSlide().toString());
        System.out.print("\n******************************");
        System.out.print(" " + x + " ");
        System.out.print("******************************\n");
    }
    public int currentSlide()
    {
        SlideNode temp = new SlideNode();
        temp = head;
        int position=1;
        while(temp!=cursor)
        {
            temp = temp.getNext();
            position++;
        }
        return position;
    }
    public int listLength()
    {
        System.out.println("In Length of List metho");
        SlideNode nodePtr = head;
        int answer = 1;
        while(nodePtr != tail)
        {
            System.out.println("In Length of List loop");
            answer++;
            nodePtr = nodePtr.getNext();
        }
        return answer;
    }
    public boolean removeCurrentSlide() 
    {
        if(cursor!=null)
        {
            cursor = cursor.getPrev();
            cursor.getNext().getNext().setPrev(cursor);
            cursor.setNext(cursor.getNext().getNext());
            cursor = cursor.getNext();
            return true;
        }
        return false;
    }
    public void addAfterCurrent(Slide newSlide)
    {
        SlideNode node = new SlideNode(newSlide);
        if(cursor==null)
        {
            addToEnd(newSlide);
        }
        else
        {
            node.setNext(cursor.getNext());
            node.setPrev(cursor);
            node.getNext().setPrev(node);
            cursor.setNext(node);

            cursor = cursor.getNext();

            if(cursor.getNext() == null)
            {
                tail = cursor;
            }
        }
    }
    public void addToEnd(Slide newSlide)
    {
        SlideNode node = new SlideNode(newSlide);
        if(isEmpty())
        {
            System.out.println("Created list");
            head = node;
            tail = node;
            cursor = node;
        }
        else
        {
            while(cursor!=null)
            {
                cursor = cursor.getNext();
            }
            tail.setNext(node);
            node.setPrev(tail);
            node.setNext(head);
            tail = node;
            cursor = node;

        }
        System.out.println("Out of addToEnd");
    }
    public boolean isEmpty()
    {
        return (cursor==null);
    }
    public boolean moveForward()
    {
        if(cursor!=tail)
        {
            cursor = cursor.getNext();

            return true;
        }
        else
            return false;       
    }
    public boolean moveBack()
    {
        if(cursor!=head)
        {
            cursor = cursor.getPrev();

            return true;
        }
        else
            return false;       
    }
    public void resetCursor()
    {
        cursor = head;
    }

    public static void main(String[] args)
    {
        BufferedReader input = new BufferedReader(new InputStreamReader(System.in));
        try 
        {


            SlideList slides = new SlideList();

            System.out.println("AddToEnd");

            Slide newSlide = new Slide();
            newSlide.setData("1", "2", "3", "4", "5");
            slides.addToEnd(newSlide);
            slides.displayCurrentSlide();

            System.out.println("AddToEnd");

            Slide newSlide1 = new Slide();
            newSlide1.setData("2", "3", "3", "4", "5");
            slides.addToEnd(newSlide1);
            slides.displayCurrentSlide();

            System.out.println("AddToEnd");

            Slide newSlide2 = new Slide();
            newSlide2.setData("3", "4", "5", "6", "7");
            slides.addToEnd(newSlide2);
            slides.displayCurrentSlide();

            /*System.out.println("AddToEnd/ResetCursor");

            Slide newSlide3 = new Slide();
            newSlide3.setData("4", "5", "6", "7", "8");
            slides.resetCursor();
            slides.addToEnd(newSlide3);
            slides.displayCurrentSlide();
            System.out.println("Length of List");
            System.out.println(slides.listLength());
            System.out.println("Displaying All Slides");
            slides.displaySlides(1, 10);*/

        }
        /*catch (IOException e) 
        {
            System.out.println(e.getMessage());
        } */
        catch (EmptyListException e)
        {
            System.out.println(e.getMessage());
        }


    }


}

1 个答案:

答案 0 :(得分:0)

首先,大多数链接列表可能有多个项目可能访问它,因此Cursor不是列表的固有部分,而是“列表的访问者”。

其次,你要做错事,你需要知道你打算做什么。我们或许可以找到答案(正如我上面所做的那样);但是,没有人知道这是否是您特定问题的正确答案。描述问题(提供示例),我们将尽力描述为什么出现意外行为。