java - Implementing an ADT linked list from scratch -


i've got class project have build adt-based linked list scratch (meaning can't use standard java adts) , use sort bunch of state objects (that each contain linked list of cities) alphabetically. backbone of code is, obviously, handmade orderedlinkedlist class, , i'm having lot of trouble figuring out how implement, speficially, findoradd method iterates through list and, if argument passed not in list, adds in appropriate spot (and returns element if it's there). of things i've read implementing linked lists don't deal in adts , it's difficult convert in mind , still wrap head around it. (admittedly incomplete) oll code , accompanying iterator:

import java.util.iterator;  public class orderedlinkedlist<e extends comparable<e>> implements iterable<e>  {     private e first;     private e next;     private e last;     private e current;     private e temp;     private int size;      public orderedlinkedlist()      {         this.first = null;         this.next = null;         this.last = null;         this.current = null;         this.size = 0;     }      public e findoradd(e element)     {         e returnval = null;         iterator<e> listiter = this.iterator();          if (this.first == null)         {             this.first = element;             this.size++;         }          else              (int = 0; < this.size; i++)                 {                     if (listiter.next().compareto(element) == 1 && listiter.hasnext() == false)                     {                         temp = this.first;                         this.first = element;                         this.next = temp;                         this.size++;                     }                        else if (listiter.next().compareto(element) == 1 && listiter.hasnext() == true)                         continue;                     else if (listiter.next().compareto(element) == 0)                         returnval = element;                     else if (listiter.next().compareto(element) == -1)                     {                         temp = this.next;                         this.next = element;                                             }                                }          return returnval;     }      public iterator<e> iterator()     {         return new ordlistiterator<e>();     }      private class ordlistiterator<e> implements iterator<e>      {         private e nextnode;          public ordlistiterator()         {             //maybe needed here         }          public boolean hasnext()         {             return (next != null);         }          public e next()         {                    return (e) next;         }          public e first()         {             return (e) first;         }          public void remove()         {             //implement later         }     } } 

i've got compareto() methods in state , city classes override usual method still function same way. going wrong in findoradd? how going wrong? i'm not looking full correction of code or anything; i'm 99% sure under else block abysmal. need push in right direction: someplace foothold. i'd hugely appreciate advice.

i believe issue may lie in fact calling listiter.next() each condition may mean pushing iterator through @ each check. possibly should store @ beginning of loop use single object in comparisons...


Comments

Popular posts from this blog

matlab - error with cyclic autocorrelation function -

django - (fields.E300) Field defines a relation with model 'AbstractEmailUser' which is either not installed, or is abstract -

c# - What is a good .Net RefEdit control to use with ExcelDna? -