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]
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。