联系方式

您当前位置:首页 >> Java编程Java编程

日期:2024-03-09 03:19

Project 2 (Deques and Randomized Queues)


Goal The purpose of this project is to implement elementary data structures using arrays and linked lists, and to introduce you to generics and iterators.


Problem 1. (Deque) A double-ended queue or deque  (pronounced “deck”) is a generalization of a stack and a queue that supports adding and removing items from either the front or the back of the data structure.  Create a generic, iterable data type called LinkedDeque that uses a doubly-linked list to implement the following deque API:


LinkedDeque


LinkedDeque()                     constructs an empty deque


boolean isEmpty()                returns true if this deque empty, and false otherwise


int size()                             returns the number of items on this deque


void addFirst(Item item)       adds item to the front of this deque


void addLast(Item item)        adds item to the back of this deque


Item peekFirst()                    returns the item at the front of this deque


Item removeFirst()                removes and returns the item at the front of this deque


Item peekLast()                     returns the item at the back of this deque


Item removeLast()                 removes and returns the item at the back of this deque


Iterator iterator()                  returns an iterator to iterate over the items in this deque from front to back


String toString()                     returns a string representation of this deque


Corner Cases


❼ The add*()  methods should throw a NullPointerException("item  is  null")  if item is null.


❼ The peek*()  and remove*()  methods should throw a NoSuchElementException("Deque  is  empty")  if the deque is empty.


❼ The next()  method in the deque iterator shoud throw a NoSuchElementException("Iterator  is  empty")  if there are no more items to iterate.


Performance Requirements


❼ The constructor and methods in LinkedDeque  and DequeIterator  should run in time T (n) ~ 1.


>_ ~/workspace/project2


$ java LinkedDeque


Filling the deque ...


The deque (364 characters ): There is grandeur in this view of life , with its several powers , having been originally breathed into a few forms or into one ; and that , whilst this planet has gone cycling on according to the fixed law of gravity , from so simple a beginning endless forms most beautiful and most wonderful have been , and are being , evolved . ~ Charles Darwin , The Origin of Species


Emptying the deque ...


deque . isEmpty ()? true


Directions:


❼ Use a doubly-linked list Node  to implement the API — each node in the list stores a generic item, and references next  and prev to the next and previous nodes in the list


null ← item1 ↔ item2 ↔ item3 ↔ · · · ↔ itemn → null


❼ Instance variables:


– Reference to the front of the deque, Node  first.


– Reference to the back of the deque, Node  last.


– Size of the deque, int  n.


❼ LinkedDeque()


– Initialize instance variables to appropriate values.


❼ boolean  isEmpty()


– Return whether the deque is empty or not.


❼ int  size()


– Return the size of the deque.


❼ void  addFirst(Item  item)


– Add the given item to the front of the deque.


– Increment n by one.


– If this is the irst item that is being added, both first  and last  must point to the same node.


❼ void  addLast(Item  item)


– Add the given item to the back of the deque.


– Increment n by one.


– If this is the irst item that is being added, both first  and last  must point to the same node.


❼ Item  peekFirst()


– Return the item at the front of the deque.


❼ Item  removeFirst()


– Remove and return the item at the front of the deque.


– Decrement n  by one.


– If this is the last item that is being removed, both first  and last  must point to null.


❼ Item  peekLast()


– Return the item at the back of the deque.


❼ Item  removeLast()


– Remove and return the item at the back of the deque.


– Decrement n  by one.


– If this is the last item that is being removed, both first  and last  must point to null.


❼ Iterator  iterator()


– Return an object of type DequeIterator.


❼ LinkedDeque  :: DequeIterator.


– Instance variable:


✯ Reference to current node in the iterator, Node  current.


– DequeIterator()


✯ Initialize instance variable appropriately.


– boolean  hasNext()


✯ Return whether the iterator has more items to iterate or not.


– Item  next()


✯ Return the item in current  and advance current  to the next node.


Problem 2. (Sorting  Strings) Implement a program called Sort.java  that accepts strings from standard input, stores them in a LinkedDeque  data structure, sorts the deque, and writes the sorted strings to standard output.


Performance Requirements


❼ The program should run in time T (n) ~ n2 , where n is the number of input strings.


>_ ~/workspace/project2


$ java Sort


A B R A C A D A B R A



A


A


A


A


A


B


B


C


D


R


R


Directions:


❼ Create a queue d.


❼ For each word w  read from standard input


– Add w  to the front of d  if it is less+  than the irst word in d.


– Add w to the back of d  if it is greater+  than the last word in d.


– Otherwise, remove words that are less than w  from the front of d  and store them in a temporary stack s ; add w  to the front of d ; and add words from s  also to the front of d.


❼ Write the words from d  to standard output.


y Use the helper method boolean  less(String  v,  String  w)  to test if a string v  is less than a string w.


Problem 3. (Random   Queue) A random queue is similar to a stack or queue,  except that the item removed is chosen uniformly at random from items in the data structure. Create a generic, iterable data type called ResizingArrayRandomQueue that uses a resizing array to implement the following random queue API:


ResizingArrayRandomQueue


ResizingArrayRandomQueue()              constructs an empty random queue


boolean isEmpty()                               returns true if this queue is empty, and false otherwise


int size()                                             returns the number of items in this queue


void enqueue(Item item)                      adds item to the end of this queue


Item sample()                                      returns a random item from this queue


Item dequeue()                                    removes and returns a random item from this queue


Iterator iterator()                                returns an independent† iterator to iterate over the items in this queue in random order


String toString()                                     returns a string representation of this queue


The order of two or more iterators on the same randomized queue must be mutually independent, ie, each iterator must maintain its own random order.


Corner Cases


❼ The enqueue()  method should throw a NullPointerException("item  is  null")  if item is null.


❼ The sample() and dequeue() methods should throw a NoSuchElementException("Random  queue  is  empty") if the random queue is empty.


❼ The next()  method in the random queue iterator shoud throw a NoSuchElementException("Iterator  is  empty")  if there are no more items to iterate.


Performance Requirements


❼ The constructor and methods in ResizingArrayRandomQueue  should run in time T (n)     1.


❼ The constructor in RandomQueueIterator  should run in time T (n)     n.


❼ The methods in RandomQueueIterator  should run in time T (n)     1.


>_ ~/workspace/project2


$ java ResizingArrayRandomQueue


sum = 5081434


iterSumQ = 5081434


dequeSumQ = 5081434


iterSumQ + dequeSumQ == 2 * sum ? true


Directions:


❼ Use a resizing array to implement the API


❼ Instance variables:


– Array to store the items of queue, Item[]  q.


– Size of the queue, int  n.


❼ ResizingArrayRandomQueue()


– Initialize instance variables appropriately — create q  with an initial capacity of 2.


❼ boolean  isEmpty()


– Return whether the queue is empty or not.


❼ int  size()


– Return the size of the queue.


❼ void  enqueue(Item  item)


– If q  is at full capacity, resize it to twice its current capacity.


– Insert the given item in q  at index n.


– Increment n by one.


❼ Item  sample()


– Return q[r] , where r  is a random integer from the interval  [0,  n) .


❼ Item  dequeue()


– Save q[r]  in item, where r  is a random integer from the interval [0,  n) .


– Set q[r] to q[n  -  1]  and q[n  -  1] to null.


– Decrement n  by one.


– If q  is at quarter capacity, resize it to half its current capacity.


– Return item.


❼ Iterator  iterator()


– Return an object of type RandomQueueIterator.


❼ ResizingArrayRandomQueue  :: RandomQueueIterator()


– Instance variables:


✯ Array to store the items of q, Item[]  items.


✯ Index of the current item in items, int  current.


– RandomQueueIterator()


✯ Create items with capacity n.


✯ Copy the n  items from q  into items.


✯ Shu   e items.


✯ Initialize current  appropriately.


– boolean  hasNext()


✯ Return whether the iterator has more items to iterate or not.


– Item  next()


✯ Return the item in items  at index current  and advance current  by one.


Problem 4. (Sampling  Integers) Implement a program called Sample.java  that accepts lo  (int), hi (int), k (int), and mode (String) as command-line arguments, uses a random queue to sample k integers from the interval  [lo, hi], and writes the samples to standard output.  The sampling must be done with replacement if mode is  “+”, and without replacement if mode is “-”. You may assume that k     hi - lo + 1.


Corner Cases


❼ The program should throw an IllegalArgumentException("Illegal  mode")  if mode is diferent from “+” or “-” .


Performance Requirements


❼ The program should run in time T (k, n)      kn in the worst case (sampling without replacement), where k is the sample size and n is the length of the sampling interval.


>_ ~/workspace/project2


$ java Sample 1 5 5 +


3


3


5


4


1


$ java Sample 1 5 5 -


2


3


1


4


5


Directions:


❼ Accept lo (int), hi (int), k (int), and mode (String) as command-line arguments.


❼ Create a random queue q containing integers from the interval  [lo, hi].


❼ If mode is “+” (sampling with replacement), sample and write k integers from q to standard output.


❼ If mode is “-” (sampling without replacement), dequeue and write k integers from q to standard. output


Acknowledgements This project is an adaptation of the Deques and Randomized Queues assignment developed at Princeton University by Kevin Wayne.


Files to Submit


1. LinkedDeque.java


2.  Sort.java


3. ResizingArrayRandomQueue.java


4.  Sample.java


5. notes.txt


Before you submit your iles, make sure:


❼ You do not use concepts outside of what has been taught in class.


❼ Your code is adequately commented, follows good programming principles, and meets any speciic requirements such as corner cases and running times.


❼ You edit the sections (#1 mandatory, #2 if applicable, and #3 optional) in the given notes.txt ile as appropriate. Section #1 must provide a clear high-level description of the project in no more than 200 words.


版权所有:留学生编程辅导网 2020 All Rights Reserved 联系方式:QQ:821613408 微信:horysk8 电子信箱:[email protected]
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:horysk8