⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 linkedlist2.java

📁 java编程代码
💻 JAVA
字号:

import java.util.NoSuchElementException;

public class LinkedList2
{
    private class Node
    {
        private String item;
        private Node link;
        public Node( )
        {
             item = null;
             link = null;
        }

        public Node(String newItem, Node linkValue)
        {
            item = newItem;
            link = linkValue;
        }
     }//End of Node inner class

    /**
     If the list is altered any iterators should invoke restart or
     the iterator's behavior may not be as desired.
    */
    public class List2Iterator
    {
        private Node position;
        private Node previous;//previous value of position

        public List2Iterator( )
        {
            position = head; //Instance variable head of outer class.
            previous = null;
        }

        public void restart( )
        {
            position = head; //Instance variable head of outer class.
            previous = null;
        }

        public String next( )
        {
            if (!hasNext( ))
                throw new NoSuchElementException( );

            String toReturn = position.item;
            previous = position;
            position = position.link;
            return toReturn;
        }

        public boolean hasNext( )
        {
            return (position != null);
        }

        /**
         Returns the next value to be returned by next( ).
         Throws an IllegalStateExpression if hasNext( ) is false.
        */
        public String peek( )
        {
             if (!hasNext( ))
                throw new IllegalStateException( );
             return position.item;
        }

        /**
         Adds a node before the node at location position.
         previous is placed at the new node. If hasNext( ) is
         false, then the node is added to the end of the list.
         If the list is empty, inserts node as the only node.
        */
        public void addHere(String newData)
		{
		    if (position == null && previous != null)
		    //if at end of list
		        previous.link =
		                     new Node(newData, null);
		    else if (position == null || previous == null)
		    //else if list is empty or position is at head node.
		        LinkedList2.this.addToStart(newData);
		    else//previous and position are located
		        //at two consecutive nodes.
		    {
		        Node temp = new Node(newData, position);
		        previous.link = temp;
		        previous = temp;
		    }
	    }

        /**
         Changes the String in the node at location position.
         Throws an IllegalStateException if position is not at a node,
        */
        public void changeHere(String newData)
		{
		    if (position == null)
		        throw new IllegalStateException( );
		    else
		        position.item = newData;
        }

        /**
         Deletes the node at location position and
         moves position to the "next" node.
         Throws an IllegalStateException if the list is empty.
        */
        public void delete( )
		{
		    if (position == null)
		        throw new IllegalStateException( );
		    else if (previous == null)
		    {//remove node at head
		        head = head.link;
		        position = head;
		    }
		    else //previous and position are at two nodes.
		    {
		        previous.link = position.link;
		        position = position.link;
		    }
        }
     }//End of List2Iterator inner class

    private Node head;

    public List2Iterator iterator( )
    {
        return new List2Iterator( );
    }

    public LinkedList2( )
    {
        head = null;
    }

    /**
     Adds a node at the start of the list with the specified data.
     The added node will be the first node in the list.
    */
    public void addToStart(String itemName)
    {
        head = new Node(itemName, head);
    }

    /**
     Removes the head node and returns true if the list contains at least
     one node. Returns false if the list is empty.
    */
    public boolean deleteHeadNode( )
    {
        if (head != null)
        {
            head = head.link;
            return true;
        }
        else
            return false;
    }

    /**
     Returns the number of nodes in the list.
    */
    public int size( )
    {
        int count = 0;
        Node position = head;
        while (position != null)
        {
            count++;
            position = position.link;
        }
        return count;
    }

    public boolean contains(String item)
    {
        return (find(item) != null);
    }

    /**
     Finds the first node containing the target item, and returns a
     reference to that node. If target is not in the list, null is returned.
    */
    private Node find(String target)
    {
        Node position = head;
        String itemAtPosition;
        while (position != null)
        {
            itemAtPosition = position.item;
            if (itemAtPosition.equals(target))
                return position;
            position = position.link;
        }
        return null; //target was not found
    }

    public void outputList( )
    {
        Node position = head;
        while (position != null)
        {
            System.out.println(position.item );
            position = position.link;
        }
    }

    public boolean isEmpty( )
    {
        return (head == null);
    }

    public void clear( )
    {
        head = null;
    }


   /*
    For two lists to be equal they must contain the same data items in
    the same order.
   */
   public boolean equals(Object otherObject)
    {
        if (otherObject == null)
            return false;
        else if (getClass( ) != otherObject.getClass( ))
            return false;
        else
        {
            LinkedList2 otherList = (LinkedList2)otherObject;
            if (size( ) != otherList.size( ))
                return false;
            Node position = head;
            Node otherPosition = otherList.head;
            while (position != null)
            {
                if ( (!(position.item.equals(otherPosition.item))))
                   return false;
                position = position.link;
                otherPosition = otherPosition.link;
            }
            return true; //A mismatch was not found
        }
    }

}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -