© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 8 Collection.

Slides:



Advertisements
Similar presentations
Chapter 24 Lists, Stacks, and Queues
Advertisements

COSC 1P03 Data Structures and Abstraction 9.1 The Queue Whenever you are asked if you can do a job, tell 'em, "Certainly, I can!" Then get busy and find.
Stacks, Queues, and Deques. 2 A stack is a last in, first out (LIFO) data structure Items are removed from a stack in the reverse order from the way they.
Chapter 5 Queues Modified. Chapter Scope Queue processing Comparing queue implementations 5 - 2Java Software Structures, 4th Edition, Lewis/Chase.
© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 11 Implementing.
1 Chapter 24 Lists Stacks and Queues. 2 Objectives F To design list with interface and abstract class (§24.2). F To design and implement a dynamic list.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All rights reserved L11 (Chapter 20) Lists, Stacks,
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All rights reserved L16 (Chapter 22) Java Collections.
Main Index Contents 11 Main Index Contents Container Types Container Types Sequence Containers Sequence Containers Associative Containers Associative Containers.
CHAPTER 6 Stacks Array Implementation. 2 Stacks A stack is a linear collection whose elements are added and removed from one end The last element to be.
Main Index Contents 11 Main Index Contents Container Types Container Types Sequence Containers Sequence Containers Associative Containers Associative Containers.
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. Chapter 12 – Data Structures Outline 12.1Introduction.
Liang, Introduction to Java Programming, Ninth Edition, (c) 2013 Pearson Education, Inc. All rights reserved. 1 Chapter 26 Implementing Lists, Stacks,
Liang, Introduction to Java Programming, Tenth Edition, (c) 2013 Pearson Education, Inc. All rights reserved. 1 Chapter 20 Lists, Stacks, Queues, and Priority.
Stacks, Queues, and Deques
Liang, Introduction to Java Programming, Ninth Edition, (c) 2013 Pearson Education, Inc. All rights reserved. 1 Chapter 22 Lists, Stacks, Queues, and Priority.
JAVA: An Introduction to Problem Solving & Programming, 5 th Ed. By Walter Savitch and Frank Carrano. ISBN © 2008 Pearson Education, Inc., Upper.
© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 18 Binary.
© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 17 Binary.
Chapter 3 List Stacks and Queues. Data Structures Data structure is a representation of data and the operations allowed on that data. Data structure is.
Data Structures and Abstract Data Types "Get your data structures correct first, and the rest of the program will write itself." - David Jones.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All rights reserved Chapter 22 Java Collections.
Liang, Introduction to Java Programming, Eighth Edition, (c) 2011 Pearson Education, Inc. All rights reserved Chapter 22 Java Collections.
Java™ How to Program, 9/e Presented by: Dr. José M. Reyes Álamo © Copyright by Pearson Education, Inc. All Rights Reserved.
Containers Overview and Class Vector
ADSA: Collections/ Advanced Data Structures and Algorithms Objective –give an overview of Collection classes, and create/use a Bag class Semester.
Stacks and Queues Copyright © 2011 by Maria Litvin, Gary Litvin, and Skylight Publishing. All rights reserved. Java Methods Object-Oriented Programming.
Chapter 7 Stacks. © 2004 Pearson Addison-Wesley. All rights reserved 7-2 The Abstract Data Type: Developing an ADT During the Design of a Solution Specifications.
Main Index Contents 11 Main Index Contents Week 3 – The Vector Container.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2005 Pearson Education, Inc. All rights reserved Chapter 20 Lists, Stacks,
© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 16 Binary.
1/ 124 COP 3503 FALL 2012 SHAYAN JAVED LECTURE 18 Programming Fundamentals using Java 1.
C++ STL CSCI 3110.
Chapter 18 Java Collections Framework
30 May Stacks (5.1) CSE 2011 Winter Stacks2 Abstract Data Types (ADTs) An abstract data type (ADT) is an abstraction of a data structure An.
CSS446 Spring 2014 Nan Wang  Java Collection Framework ◦ LinkedList ◦ Set ◦ Map 2.
1 Chapter 17 Object-Oriented Data Structures. 2 Objectives F To describe what a data structure is (§17.1). F To explain the limitations of arrays (§17.1).
ADSA: Linked Lists/ Advanced Data Structures and Algorithms Objective – –implement and use linked lists Semester 2, Linked.
Chapter 12 Collections. © 2004 Pearson Addison-Wesley. All rights reserved12-2 Collections A collection is an object that helps us organize and manage.
© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 10 Linked.
© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 5 Generic.
CIS3023: Programming Fundamentals for CIS Majors II Summer 2010 Ganesh Viswanathan Generics and Collections Course Lecture Slides 19 th July 2010 “Never.
© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 13 Implementing.
© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 14 Stacks.
Collections Data structures in Java. OBJECTIVE “ WHEN TO USE WHICH DATA STRUCTURE ” D e b u g.
Chapter 15 Linked Data Structures Slides prepared by Rose Williams, Binghamton University Kenrick Mock University of Alaska Anchorage Copyright © 2008.
Liang, Introduction to Java Programming, Tenth Edition, (c) 2013 Pearson Education, Inc. All rights reserved. 1 Chapter 20 Lists, Stacks, Queues, and Priority.
1 Stacks (Continued) and Queues Array Stack Implementation Linked Stack Implementation The java.util.Stack class Queue Abstract Data Type (ADT) Queue ADT.
Chapter 5 Array-Based Structures © 2006 Pearson Education Inc., Upper Saddle River, NJ. All rights reserved.
© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 4 Introduction.
CMSC 202 Containers and Iterators. Container Definition A “container” is a data structure whose purpose is to hold objects. Most languages support several.
JAVA: An Introduction to Problem Solving & Programming, 6 th Ed. By Walter Savitch ISBN © 2012 Pearson Education, Inc., Upper Saddle River,
“The desire for safety stands against every great and noble enterprise.” – Tacitus Thought for the Day.
© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 12 Iterators.
© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 20 Ordered.
C Programming Day 2. 2 Copyright © 2005, Infosys Technologies Ltd ER/CORP/CRS/LA07/003 Version No. 1.0 Union –mechanism to create user defined data types.
Click to edit Master text styles Stacks Data Structure.
Java Collections Framework The client view. The Big Picture.
Linked Data Structures
Set Collection A Bag is a general collection class that implements the Collection interface. A Set is a collection that resembles a Bag with the provision.
Generic Classes and Methods
Collections Framework
Sieve of Eratosthenes The Sieve of Eratosthenes uses a bag to find all primes less than or equal to an integer value n. Begin by creating a bag an inserting.
Introduction to Data Structure
Stacks, Queues, and Deques
Presentation transcript:

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 8 Collection Types Bret Ford © 2005, Prentice Hall

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Collection A collection is an object that holds other objects. It is a storage mechanism with operations for adding and removing elements and for accessing and perhaps updating their values. A collection is an object that holds other objects. It is a storage mechanism with operations for adding and removing elements and for accessing and perhaps updating their values.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Collection Interface The generic Collection interface defines a set of operations that characterize the behavior of most collection classes. The generic Collection interface defines a set of operations that characterize the behavior of most collection classes.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Collection Interface (continued)

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Collection Interface (concluded)

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. List Collection A List collection stores elements by position and includes index-based operations. A List collection stores elements by position and includes index-based operations. The List interface extends the Collection interface by adding index-based operations. These allow for insertion, deletion, access, and updates at an index position in the list. The List interface extends the Collection interface by adding index-based operations. These allow for insertion, deletion, access, and updates at an index position in the list.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. ArrayList Collection An ArrayList collection is a generalized array that sores element in a contiguous block of memory. The collection is dynamic in that it automatically expands to handle insert of new elements. An ArrayList collection is a generalized array that sores element in a contiguous block of memory. The collection is dynamic in that it automatically expands to handle insert of new elements. An ArrayList is a direct-access structure An ArrayList is a direct-access structure

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. ArrayList Collection (concluded) The collection efficiently (O(1)) inserts and deletes elements at the rear of the list. The operations at intermediate positions have O(n) efficiency since the tail of the list must be shifted right (insertion) or left (deletion). The collection efficiently (O(1)) inserts and deletes elements at the rear of the list. The operations at intermediate positions have O(n) efficiency since the tail of the list must be shifted right (insertion) or left (deletion).

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. LinkedList Collection A LinkedList collection is a sequence whose elements have a value and links that identify adjacent elements in the sequence. A LinkedList collection is a sequence whose elements have a value and links that identify adjacent elements in the sequence. A LinkedList is a sequential- access structure. A LinkedList is a sequential- access structure.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. LinkedList Collection (concluded) Inserting or deleting elements in a LinkedList involves altering the links that connect the elements in the list. These are O(1) operations. Inserting or deleting elements in a LinkedList involves altering the links that connect the elements in the list. These are O(1) operations. A Linked List class can be extended to the OrderedList class that creates collections that store elements in order.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Set Collection A Bag is a general collection class that implements the Collection interface. A Set is a collection that resembles a Bag with the provision that duplicate values are not allowed. A Bag is a general collection class that implements the Collection interface. A Set is a collection that resembles a Bag with the provision that duplicate values are not allowed. Applications typically use Set collections for operations set union, set intersection, and set difference.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Map Collection A Map is a collection of key-value pairs. The key uniquely identifies the element while the value field typically has associated data. Access to an element requires only the key and returns the value component. For this reason, a Map is referred to as an associative array. A Map is a collection of key-value pairs. The key uniquely identifies the element while the value field typically has associated data. Access to an element requires only the key and returns the value component. For this reason, a Map is referred to as an associative array.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Stack Collection A Stack is a collection with a single reference point called the top of the stack. An element is added at the top of the stack (push operation) and removed from the top of the stack (pop operation). A Stack is a collection with a single reference point called the top of the stack. An element is added at the top of the stack (push operation) and removed from the top of the stack (pop operation). Elements come off a stack in the reverse order of their insertion and so a stack has last-in-first-out (LIFO) ordering. Elements come off a stack in the reverse order of their insertion and so a stack has last-in-first-out (LIFO) ordering.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Queue Collection A Queue is a collection that allows access only at the front and the back. Items enter at the back (push operation) and exit from the front of the queue (pop operation). A Queue is a collection that allows access only at the front and the back. Items enter at the back (push operation) and exit from the front of the queue (pop operation). Elements come off a queue in the same order of their insertion and so a queue has first-in-first- out (FIFO) ordering. Elements come off a queue in the same order of their insertion and so a queue has first-in-first- out (FIFO) ordering.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Priority Queue A Priority Queue is a collection that has restricted access operations, like a stack and a queue. An element can enter the queue in any order. Once in the collection, a delete operation removes the maximum (minimum) value, depending on the specified type of priority. A Priority Queue is a collection that has restricted access operations, like a stack and a queue. An element can enter the queue in any order. Once in the collection, a delete operation removes the maximum (minimum) value, depending on the specified type of priority.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Graph Collection A Graph is a set of vertices connected by links, called edges. Depending on the application, an edge may or may not have a direction and/or a weight. A digraph has directed edges; a weighted graph has edges with weights. A Graph is a set of vertices connected by links, called edges. Depending on the application, an edge may or may not have a direction and/or a weight. A digraph has directed edges; a weighted graph has edges with weights.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Java Collection Framework The Java Collection Framework is a group of collections defined using interfaces abstract classes, and inheritance. The Java Collection Framework is a group of collections defined using interfaces abstract classes, and inheritance.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Bag Collection The Bag class is a generic collection that implements the Collection interface. Duplicate values are allowed. The Bag class is a generic collection that implements the Collection interface. Duplicate values are allowed. In the Bag class, the method grab() returns a random element in the collection. The method toString() returns a comma-separated list of elements enclosed in brackets. In the Bag class, the method grab() returns a random element in the collection. The method toString() returns a comma-separated list of elements enclosed in brackets.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Program 8.1 import ds.util.Bag; import ds.util.Arrays; import java.util.Scanner; public class Program8_1 { public static void main(String[] args) { // keyboard input stream and input string Scanner keyIn = new Scanner(System.in); String str = ""; // Bag objects hold string characters Bag bagA, bagB; The program uses Bag collections to identify distinct elements in a string and displays them in an ordered list. Input of the string comes from the keyboard.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Program 8.1 (continued) // Character object for char // in the input string Character ch; // flag used to remove duplicates from bagA boolean foundDuplicate; // prompt for input string System.out.print("Enter a string: "); str = keyIn.next(); // create the collections with // capacity str.length() bagA = new Bag (str.length()); bagB = new Bag (str.length()); // add characters from the string to bagA for (int i = 0; i < str.length(); i++) bagA.add(str.charAt(i));

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Program 8.1 (continued) // use grab() to fetch a character from // bagA; add it to bagB and then remove // all occurrences of the character // from bagA; continue this process until // bagA is empty while (!bagA.isEmpty()) { // remove a random character from bagA // and add to bagB ch = bagA.grab(); bagB.add(ch); // remove all occurrence of // target = chObj from bagA do foundDuplicate = bagA.remove(ch); while (foundDuplicate); }

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Program 8.1 (concluded) // create array of Object references // corresponding to elements in bagB; sort // array and output its values using static // methods sort() and toString(arr) Object[] objArr = bagB.toArray(); Arrays.sort(objArr); System.out.println("Sorted letters: " + Arrays.toString(objArr)); } Run: Enter a string: mississippi Sorted letters: [i, m, p, s]

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Sieve of Eratosthenes The Sieve of Eratosthenes uses a bag to find all primes less than or equal to an integer value n. Begin by creating a bag an inserting values from 2 to n. Using values 2, 3, 4, and so forth, remove all multiple, leaving only the prime numbers. E.g. The figure illustrates the sieve of Eratosthenes when finding all prime numbers in the range from 2 through 25. The Sieve of Eratosthenes uses a bag to find all primes less than or equal to an integer value n. Begin by creating a bag an inserting values from 2 to n. Using values 2, 3, 4, and so forth, remove all multiple, leaving only the prime numbers. E.g. The figure illustrates the sieve of Eratosthenes when finding all prime numbers in the range from 2 through 25.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. The method sieve(n) public static Bag sieve(int n) { int m, i; Bag primeBag = new Bag (n); // load the set with integers 2, 3,..., n for (m = 2; m <= n; m++) primeBag.add(new Integer(m)); // find the primes using the Sieve of Eratosthenes; // look at numbers from // m = 2 to m * m > n (m <= sqrt(n)) for (m = 2; m * m <= n; m++)

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. sieve(n) (concluded) // check if m is still in the set; if so // remove all multiples of m starting with 2*m if(primeBag.contains(new Integer(m))) { // i sequences through successive multiples of m, // 2*m, 3*m,... i = 2 * m; while (i <= n) { primeBag.remove(new Integer(i)); // update i to the next multiple of m i += m; } return primeBag; }

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Program 8.2 import ds.util.Bag; public class Program8_2 { public static void main(String[] args) { final int PRIMELIMIT = 500; Bag bag; // call sieve() and return the bag of primes bag = sieve(PRIMELIMIT); // list elements in the bag as an array // output primes in 6 spaces, 10 per line writePrimes(bag.toArray()); System.out.println(); } The program uses the Sieve of Eratosthenes to display all primes from 2 to PRIMELIMIT = 500.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Program 8.2 (continued) // output elements in the array // in 6 spaces, 10 per line public static void writePrimes(Object[] arr) { String intStr; int count = 1, i; // initialize sb with 6 blanks StringBuffer sb = new StringBuffer(" "); for (i = 0; i < arr.length; i++) { // convert integer to a string intStr = arr[i].toString(); // use replace() to place intStr // in the string buffer. sb.replace(0, intStr.length(), intStr); // output string buffer as a string System.out.print(sb.toString());

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Program 8.2 (concluded) // every 10 elements output a newline if(count % 10 == 0) System.out.println(); count++; } }

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Program 8.2 (Run) Run:

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Implementing the Bag Class public class Bag implements Collection { private T[] bagArr; // storage structure private int bagSize; // size of collection // used by grab() private static Random rnd = new Random(); // private methods used by the public methods... The Bag class uses a fixed-size array as the storage structure. The size of the array is dependent on a constructor argument.

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Implementing the Bag Class (concluded) // constructor creates an empty collection // with fixed capacity public Bag(int capacity) { // value of capacity is maximum number of elements bagArr = (T[])new Object[capacity]; bagSize = 0; } // interface methods and the grab() method... }

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Private remove(int i) Method // remove the element bagArr[i] by moving the tail of // the array left one position and decrementing bagSize private void remove(int i) { // copy bagArr[i+1]... bagArr[bagSize-1] // left one position for (int j=i; j < bagSize-1; j++) bagArr[j] = bagArr[j+1]; // decrement bagSize bagSize--; }

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. General remove(item) Method public boolean remove(Object item) { // scan for item using equals() as the test for (int i=0;i < bagSize;i++) if (bagArr[i].equals(item)) { // call private remove method to delete bagArr[i] remove(i); return true; } return false; }

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. add(item) Method public boolean add(T item) { boolean returnValue; if (bagSize >= bagArr.length) return false; else { // append item at index bagSize bagArr[bagSize] = item; // increment bagSize and return true bagSize++; return true; }

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. grab() Method // return value of random object in range (0,bagSize) public T grab() { if (bagSize == 0) return null; else return bagArr[rnd.nextInt(bagSize)]; }

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. toString() Method public String toString() { // array is copy of elements Object[] arr = toArray(); // listing of elements return Arrays.toString(arr); }