<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>http://www.lensovet.net/~sysadmin/w/index.php?action=history&amp;feed=atom&amp;title=Computer_Science%2F61b%2FHomework%2Fhw5%2Flist%2FDList.java</id>
	<title>Computer Science/61b/Homework/hw5/list/DList.java - Revision history</title>
	<link rel="self" type="application/atom+xml" href="http://www.lensovet.net/~sysadmin/w/index.php?action=history&amp;feed=atom&amp;title=Computer_Science%2F61b%2FHomework%2Fhw5%2Flist%2FDList.java"/>
	<link rel="alternate" type="text/html" href="http://www.lensovet.net/~sysadmin/w/index.php?title=Computer_Science/61b/Homework/hw5/list/DList.java&amp;action=history"/>
	<updated>2026-05-03T15:30:47Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.31.16</generator>
	<entry>
		<id>http://www.lensovet.net/~sysadmin/w/index.php?title=Computer_Science/61b/Homework/hw5/list/DList.java&amp;diff=24333&amp;oldid=prev</id>
		<title>Lensovet: Lensovet moved page CS/61b/Homework/hw5/list/DList.java to Computer Science/61b/Homework/hw5/list/DList.java</title>
		<link rel="alternate" type="text/html" href="http://www.lensovet.net/~sysadmin/w/index.php?title=Computer_Science/61b/Homework/hw5/list/DList.java&amp;diff=24333&amp;oldid=prev"/>
		<updated>2023-02-20T03:51:35Z</updated>

		<summary type="html">&lt;p&gt;Lensovet moved page &lt;a href=&quot;/~sysadmin/w/CS/61b/Homework/hw5/list/DList.java&quot; class=&quot;mw-redirect&quot; title=&quot;CS/61b/Homework/hw5/list/DList.java&quot;&gt;CS/61b/Homework/hw5/list/DList.java&lt;/a&gt; to &lt;a href=&quot;/~sysadmin/w/Computer_Science/61b/Homework/hw5/list/DList.java&quot; title=&quot;Computer Science/61b/Homework/hw5/list/DList.java&quot;&gt;Computer Science/61b/Homework/hw5/list/DList.java&lt;/a&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 03:51, 20 February 2023&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Lensovet</name></author>
		
	</entry>
	<entry>
		<id>http://www.lensovet.net/~sysadmin/w/index.php?title=Computer_Science/61b/Homework/hw5/list/DList.java&amp;diff=4021&amp;oldid=prev</id>
		<title>Lensovet: moved CS 61b/Homework/hw5/list/DList.java to CS/61b/Homework/hw5/list/DList.java:&amp;#32;fix cs 61b hierarchy</title>
		<link rel="alternate" type="text/html" href="http://www.lensovet.net/~sysadmin/w/index.php?title=Computer_Science/61b/Homework/hw5/list/DList.java&amp;diff=4021&amp;oldid=prev"/>
		<updated>2010-11-14T06:00:19Z</updated>

		<summary type="html">&lt;p&gt;moved &lt;a href=&quot;/~sysadmin/w/CS_61b/Homework/hw5/list/DList.java&quot; class=&quot;mw-redirect&quot; title=&quot;CS 61b/Homework/hw5/list/DList.java&quot;&gt;CS 61b/Homework/hw5/list/DList.java&lt;/a&gt; to &lt;a href=&quot;/~sysadmin/w/CS/61b/Homework/hw5/list/DList.java&quot; class=&quot;mw-redirect&quot; title=&quot;CS/61b/Homework/hw5/list/DList.java&quot;&gt;CS/61b/Homework/hw5/list/DList.java&lt;/a&gt;: fix cs 61b hierarchy&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 06:00, 14 November 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Lensovet</name></author>
		
	</entry>
	<entry>
		<id>http://www.lensovet.net/~sysadmin/w/index.php?title=Computer_Science/61b/Homework/hw5/list/DList.java&amp;diff=3257&amp;oldid=prev</id>
		<title>Lensovet at 07:08, 22 September 2007</title>
		<link rel="alternate" type="text/html" href="http://www.lensovet.net/~sysadmin/w/index.php?title=Computer_Science/61b/Homework/hw5/list/DList.java&amp;diff=3257&amp;oldid=prev"/>
		<updated>2007-09-22T07:08:39Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{code}}&lt;br /&gt;
 /* DList.java */&lt;br /&gt;
 &lt;br /&gt;
 package list;&lt;br /&gt;
 &lt;br /&gt;
 /**&lt;br /&gt;
  *  A DList is a mutable doubly-linked list ADT.  Its implementation is&lt;br /&gt;
  *  circularly-linked and employs a sentinel node at the head of the list.&lt;br /&gt;
  *&lt;br /&gt;
  *  DO NOT CHANGE ANY METHOD PROTOTYPES IN THIS FILE.&lt;br /&gt;
  **/&lt;br /&gt;
 &lt;br /&gt;
 public class DList extends List {&lt;br /&gt;
 &lt;br /&gt;
   /**&lt;br /&gt;
    *  (inherited)  size is the number of items in the list.&lt;br /&gt;
    *  head references the sentinel node.&lt;br /&gt;
    *  Note that the sentinel node does not store an item, and is not included&lt;br /&gt;
    *  in the count stored by the &amp;quot;size&amp;quot; field.&lt;br /&gt;
    *&lt;br /&gt;
    *  DO NOT CHANGE THE FOLLOWING FIELD DECLARATION.&lt;br /&gt;
    **/&lt;br /&gt;
 &lt;br /&gt;
   protected DListNode head;&lt;br /&gt;
 &lt;br /&gt;
   /* DList invariants:&lt;br /&gt;
    *  1)  head != null.&lt;br /&gt;
    *  2)  For any DListNode x in a DList, x.next != null.&lt;br /&gt;
    *  3)  For any DListNode x in a DList, x.prev != null.&lt;br /&gt;
    *  4)  For any DListNode x in a DList, if x.next == y, then y.prev == x.&lt;br /&gt;
    *  5)  For any DListNode x in a DList, if x.prev == y, then y.next == x.&lt;br /&gt;
    *  6)  For any DList l, l.head.myList = null.  (Note that l.head is the&lt;br /&gt;
    *      sentinel.)&lt;br /&gt;
    *  7)  For any DListNode x in a DList l EXCEPT l.head (the sentinel),&lt;br /&gt;
    *      x.myList = l.&lt;br /&gt;
    *  8)  size is the number of DListNodes, NOT COUNTING the sentinel,&lt;br /&gt;
    *      that can be accessed from the sentinel (head) by a sequence of&lt;br /&gt;
    *      &amp;quot;next&amp;quot; references.&lt;br /&gt;
    **/&lt;br /&gt;
 &lt;br /&gt;
   /**&lt;br /&gt;
    *  newNode() calls the DListNode constructor.  Use this method to allocate&lt;br /&gt;
    *  new DListNodes rather than calling the DListNode constructor directly.&lt;br /&gt;
    *  That way, only this method need be overridden if a subclass of DList&lt;br /&gt;
    *  wants to use a different kind of node.&lt;br /&gt;
    *&lt;br /&gt;
    *  @param item the item to store in the node.&lt;br /&gt;
    *  @param list the list that owns this node.  (null for sentinels.)&lt;br /&gt;
    *  @param prev the node previous to this node.&lt;br /&gt;
    *  @param next the node following this node.&lt;br /&gt;
    **/&lt;br /&gt;
   protected DListNode newNode(Object item, DList list,&lt;br /&gt;
                               DListNode prev, DListNode next) {&lt;br /&gt;
     return new DListNode(item, list, prev, next);&lt;br /&gt;
   }&lt;br /&gt;
 &lt;br /&gt;
   /**&lt;br /&gt;
    *  DList() constructs for an empty DList.&lt;br /&gt;
    **/&lt;br /&gt;
   public DList() {&lt;br /&gt;
 	  size = 0;&lt;br /&gt;
 	  head = newNode(null, null, null, null);&lt;br /&gt;
 	  head.next = head;&lt;br /&gt;
 	  head.prev = head;&lt;br /&gt;
   }&lt;br /&gt;
 &lt;br /&gt;
   /**&lt;br /&gt;
    *  insertFront() inserts an item at the front of this DList.&lt;br /&gt;
    *&lt;br /&gt;
    *  @param item is the item to be inserted.&lt;br /&gt;
    *&lt;br /&gt;
    *  Performance:  runs in O(1) time.&lt;br /&gt;
    **/&lt;br /&gt;
   public void insertFront(Object item) {&lt;br /&gt;
 	  DListNode node = newNode(item, this, head, head.next);&lt;br /&gt;
 	  head.next.prev = node;&lt;br /&gt;
 	  head.next = node;&lt;br /&gt;
 	  size++;&lt;br /&gt;
   }&lt;br /&gt;
 &lt;br /&gt;
   /**&lt;br /&gt;
    *  insertBack() inserts an item at the back of this DList.&lt;br /&gt;
    *&lt;br /&gt;
    *  @param item is the item to be inserted.&lt;br /&gt;
    *&lt;br /&gt;
    *  Performance:  runs in O(1) time.&lt;br /&gt;
    **/&lt;br /&gt;
   public void insertBack(Object item) {&lt;br /&gt;
 	  DListNode node = newNode(item, this, head.prev, head);&lt;br /&gt;
 	  head.prev.next = node;&lt;br /&gt;
 	  head.prev = node;&lt;br /&gt;
 	  size++;&lt;br /&gt;
   }&lt;br /&gt;
 &lt;br /&gt;
   /**&lt;br /&gt;
    *  front() returns the node at the front of this DList.  If the DList is&lt;br /&gt;
    *  empty, return an &amp;quot;invalid&amp;quot; node--a node with the property that any&lt;br /&gt;
    *  attempt to use it will cause an exception.  (The sentinel is &amp;quot;invalid&amp;quot;.)&lt;br /&gt;
    *&lt;br /&gt;
    *  DO NOT CHANGE THIS METHOD.&lt;br /&gt;
    *&lt;br /&gt;
    *  @return a ListNode at the front of this DList.&lt;br /&gt;
    *&lt;br /&gt;
    *  Performance:  runs in O(1) time.&lt;br /&gt;
    */&lt;br /&gt;
   public ListNode front() {&lt;br /&gt;
     return head.next;&lt;br /&gt;
   }&lt;br /&gt;
 &lt;br /&gt;
   /**&lt;br /&gt;
    *  back() returns the node at the back of this DList.  If the DList is&lt;br /&gt;
    *  empty, return an &amp;quot;invalid&amp;quot; node--a node with the property that any&lt;br /&gt;
    *  attempt to use it will cause an exception.  (The sentinel is &amp;quot;invalid&amp;quot;.)&lt;br /&gt;
    *&lt;br /&gt;
    *  DO NOT CHANGE THIS METHOD.&lt;br /&gt;
    *&lt;br /&gt;
    *  @return a ListNode at the back of this DList.&lt;br /&gt;
    *&lt;br /&gt;
    *  Performance:  runs in O(1) time.&lt;br /&gt;
    */&lt;br /&gt;
   public ListNode back() {&lt;br /&gt;
     return head.prev;&lt;br /&gt;
   }&lt;br /&gt;
 &lt;br /&gt;
   /**&lt;br /&gt;
    *  toString() returns a String representation of this DList.&lt;br /&gt;
    *&lt;br /&gt;
    *  DO NOT CHANGE THIS METHOD.&lt;br /&gt;
    *&lt;br /&gt;
    *  @return a String representation of this DList.&lt;br /&gt;
    *&lt;br /&gt;
    *  Performance:  runs in O(n) time, where n is the length of the list.&lt;br /&gt;
    */&lt;br /&gt;
   public String toString() {&lt;br /&gt;
     String result = &amp;quot;[  &amp;quot;;&lt;br /&gt;
     DListNode current = head.next;&lt;br /&gt;
     while (current != head) {&lt;br /&gt;
       result = result + current.item + &amp;quot;  &amp;quot;;&lt;br /&gt;
       current = current.next;&lt;br /&gt;
     }&lt;br /&gt;
     return result + &amp;quot;]&amp;quot;;&lt;br /&gt;
   }&lt;br /&gt;
 &lt;br /&gt;
   private static void testInvalidNode(ListNode p) {&lt;br /&gt;
     System.out.println(&amp;quot;p.isValidNode() should be false: &amp;quot; + p.isValidNode());&lt;br /&gt;
     try {&lt;br /&gt;
       p.item();&lt;br /&gt;
       System.out.println(&amp;quot;p.item() should throw an exception, but didn't.&amp;quot;);&lt;br /&gt;
     } catch (InvalidNodeException lbe) {&lt;br /&gt;
       System.out.println(&amp;quot;p.item() should throw an exception, and did.&amp;quot;);&lt;br /&gt;
     }&lt;br /&gt;
     try {&lt;br /&gt;
       p.setItem(new Integer(0));&lt;br /&gt;
       System.out.println(&amp;quot;p.setItem() should throw an exception, but didn't.&amp;quot;);&lt;br /&gt;
     } catch (InvalidNodeException lbe) {&lt;br /&gt;
       System.out.println(&amp;quot;p.setItem() should throw an exception, and did.&amp;quot;);&lt;br /&gt;
     }&lt;br /&gt;
     try {&lt;br /&gt;
       p.next();&lt;br /&gt;
       System.out.println(&amp;quot;p.next() should throw an exception, but didn't.&amp;quot;);&lt;br /&gt;
     } catch (InvalidNodeException lbe) {&lt;br /&gt;
       System.out.println(&amp;quot;p.next() should throw an exception, and did.&amp;quot;);&lt;br /&gt;
     }&lt;br /&gt;
     try {&lt;br /&gt;
       p.prev();&lt;br /&gt;
       System.out.println(&amp;quot;p.prev() should throw an exception, but didn't.&amp;quot;);&lt;br /&gt;
     } catch (InvalidNodeException lbe) {&lt;br /&gt;
       System.out.println(&amp;quot;p.prev() should throw an exception, and did.&amp;quot;);&lt;br /&gt;
     }&lt;br /&gt;
     try {&lt;br /&gt;
       p.insertBefore(new Integer(1));&lt;br /&gt;
       System.out.println(&amp;quot;p.insertBefore() should throw an exception, but &amp;quot; +&lt;br /&gt;
                          &amp;quot;didn't.&amp;quot;);&lt;br /&gt;
     } catch (InvalidNodeException lbe) {&lt;br /&gt;
       System.out.println(&amp;quot;p.insertBefore() should throw an exception, and did.&amp;quot;&lt;br /&gt;
                          );&lt;br /&gt;
     }&lt;br /&gt;
     try {&lt;br /&gt;
       p.insertAfter(new Integer(1));&lt;br /&gt;
       System.out.println(&amp;quot;p.insertAfter() should throw an exception, but &amp;quot; +&lt;br /&gt;
                          &amp;quot;didn't.&amp;quot;);&lt;br /&gt;
     } catch (InvalidNodeException lbe) {&lt;br /&gt;
       System.out.println(&amp;quot;p.insertAfter() should throw an exception, and did.&amp;quot;&lt;br /&gt;
                          );&lt;br /&gt;
     }&lt;br /&gt;
     try {&lt;br /&gt;
       p.remove();&lt;br /&gt;
       System.out.println(&amp;quot;p.remove() should throw an exception, but didn't.&amp;quot;);&lt;br /&gt;
     } catch (InvalidNodeException lbe) {&lt;br /&gt;
       System.out.println(&amp;quot;p.remove() should throw an exception, and did.&amp;quot;);&lt;br /&gt;
     }&lt;br /&gt;
   }&lt;br /&gt;
 &lt;br /&gt;
   private static void testEmpty() {&lt;br /&gt;
     List l = new DList();&lt;br /&gt;
     System.out.println(&amp;quot;An empty list should be [  ]: &amp;quot; + l);&lt;br /&gt;
     System.out.println(&amp;quot;l.isEmpty() should be true: &amp;quot; + l.isEmpty());&lt;br /&gt;
     System.out.println(&amp;quot;l.length() should be 0: &amp;quot; + l.length());&lt;br /&gt;
     System.out.println(&amp;quot;Finding front node p of l.&amp;quot;);&lt;br /&gt;
     ListNode p = l.front();&lt;br /&gt;
     testInvalidNode(p);&lt;br /&gt;
     System.out.println(&amp;quot;Finding back node p of l.&amp;quot;);&lt;br /&gt;
     p = l.back();&lt;br /&gt;
     testInvalidNode(p);&lt;br /&gt;
     l.insertFront(new Integer(10));&lt;br /&gt;
     System.out.println(&amp;quot;l after insertFront(10) should be [  10  ]: &amp;quot; + l);&lt;br /&gt;
   }&lt;br /&gt;
 &lt;br /&gt;
   public static void main(String[] argv) {&lt;br /&gt;
     testEmpty();&lt;br /&gt;
     List l = new DList();&lt;br /&gt;
     l.insertFront(new Integer(3));&lt;br /&gt;
     l.insertFront(new Integer(2));&lt;br /&gt;
     l.insertFront(new Integer(1));&lt;br /&gt;
     System.out.println(&amp;quot;l is a list of 3 elements: &amp;quot; + l);&lt;br /&gt;
     try {&lt;br /&gt;
       ListNode n;&lt;br /&gt;
       int i = 1;&lt;br /&gt;
       for (n = l.front(); n.isValidNode(); n = n.next()) {&lt;br /&gt;
 	System.out.println(&amp;quot;n.item() should be &amp;quot; + i + &amp;quot;: &amp;quot; + n.item());&lt;br /&gt;
         n.setItem(new Integer(((Integer) n.item()).intValue() * 2));&lt;br /&gt;
 	System.out.println(&amp;quot;n.item() should be &amp;quot; + 2 * i + &amp;quot;: &amp;quot; + n.item());&lt;br /&gt;
 	i++;&lt;br /&gt;
       }&lt;br /&gt;
       System.out.println(&amp;quot;After doubling all elements of l: &amp;quot; + l);&lt;br /&gt;
       testInvalidNode(n);&lt;br /&gt;
 &lt;br /&gt;
       i = 6;&lt;br /&gt;
       for (n = l.back(); n.isValidNode(); n = n.prev()) {&lt;br /&gt;
 	System.out.println(&amp;quot;n.item() should be &amp;quot; + i + &amp;quot;: &amp;quot; + n.item());&lt;br /&gt;
 	n.setItem(new Integer(((Integer) n.item()).intValue() * 2));&lt;br /&gt;
 	System.out.println(&amp;quot;n.item() should be &amp;quot; + 2 * i + &amp;quot;: &amp;quot; + n.item());&lt;br /&gt;
 	i = i - 2;&lt;br /&gt;
       }&lt;br /&gt;
       System.out.println(&amp;quot;After doubling all elements of l again: &amp;quot; + l);&lt;br /&gt;
       testInvalidNode(n);&lt;br /&gt;
 &lt;br /&gt;
       n = l.front().next();&lt;br /&gt;
       System.out.println(&amp;quot;Removing middle element (8) of l: &amp;quot; + n.item());&lt;br /&gt;
       n.remove();&lt;br /&gt;
       System.out.println(&amp;quot;l is now: &amp;quot; + l);&lt;br /&gt;
       testInvalidNode(n);    &lt;br /&gt;
       n = l.back();&lt;br /&gt;
       System.out.println(&amp;quot;Removing end element (12) of l: &amp;quot; + n.item());&lt;br /&gt;
       n.remove();&lt;br /&gt;
       System.out.println(&amp;quot;l is now: &amp;quot; + l);&lt;br /&gt;
       testInvalidNode(n);    &lt;br /&gt;
 &lt;br /&gt;
       n = l.front();&lt;br /&gt;
       System.out.println(&amp;quot;Removing first element (4) of l: &amp;quot; + n.item());&lt;br /&gt;
       n.remove();&lt;br /&gt;
       System.out.println(&amp;quot;l is now: &amp;quot; + l);&lt;br /&gt;
       testInvalidNode(n);    &lt;br /&gt;
     } catch (InvalidNodeException lbe) {&lt;br /&gt;
       System.err.println (&amp;quot;Caught InvalidNodeException that should not happen.&amp;quot;&lt;br /&gt;
                           );&lt;br /&gt;
       System.err.println (&amp;quot;Aborting the testing code.&amp;quot;);&lt;br /&gt;
     }&lt;br /&gt;
   }&lt;br /&gt;
 }&lt;/div&gt;</summary>
		<author><name>Lensovet</name></author>
		
	</entry>
</feed>