csc 1051 – data structures and algorithms i

30
CSC 1051 – Data Structures and Algorithms I Dr. Mary-Angela Papalaskari Department of Computing Sciences Villanova University Course website: www.csc.villanova.edu/~map/1051/ Some slides in this presentation are adapted from the slides accompanying Java Software Solutions by Lewi Loftus CSC 1051 M.A. Papalaskari, Villanova University Arrays of Objects & 2D Arrays

Upload: taylor-harper

Post on 31-Dec-2015

19 views

Category:

Documents


1 download

DESCRIPTION

CSC 1051 – Data Structures and Algorithms I. Arrays of Objects & 2D Arrays. Dr. Mary-Angela Papalaskari Department of Computing Sciences Villanova University Course website: www.csc.villanova.edu/~map/1051/ - PowerPoint PPT Presentation

TRANSCRIPT

Page 1: CSC 1051 – Data Structures and Algorithms I

CSC 1051 – Data Structures and Algorithms I

Dr. Mary-Angela Papalaskari

Department of Computing Sciences

Villanova University

Course website:

www.csc.villanova.edu/~map/1051/

Some slides in this presentation are adapted from the slides accompanying Java Software Solutions by Lewis & Loftus

CSC 1051 M.A. Papalaskari, Villanova University

Arrays of Objects & 2D Arrays

Page 2: CSC 1051 – Data Structures and Algorithms I

Arrays - Review

0 1 2 3 4 5 6 7 8 9

7.9 8.7 9.4 8.2 6.7 9.8 8.7 8.1 7.4 9.1

The entire arrayhas a single name index

• This array holds 10 values of type double that are indexed from 0 to 9

• The size of the array is given by: scores.length = 10

CSC 1051 M.A. Papalaskari, Villanova University

scores[2]

array element

scores

element type

scores[0] = 7.9;scores[1] = 8.7;scores[2] = 9.4;scores[3] = 8.2;scores[4] = 6.7;scores[5] = 9.8;scores[6] = 8.7;scores[7] = 8.1;scores[8] = 7.4;scores[9] = 9.1;

• Instantiation:

• Declaration: = new double[10];double[] scores

• Initialization:

Page 3: CSC 1051 – Data Structures and Algorithms I

Example: An array of Strings• String[] words = new String[5];

CSC 1051 M.A. Papalaskari, Villanova University

words -

-

-

-

-

At this point, the following line of code would throw a NullPointerException:

System.out.println(words[0]);

Page 4: CSC 1051 – Data Structures and Algorithms I

Example: An array of Strings• String[] words = new String[5];

CSC 1051 M.A. Papalaskari, Villanova University

• Now, store some String objects in the array:

words[0]= "friendship";words[1] = "loyalty"; words[2] = "honor”;

"friendship"words

-

-

"loyalty"

"honor"

Page 5: CSC 1051 – Data Structures and Algorithms I

Arrays of Objects

• The following declaration creates an array object called verbs and fills it with four String objects created using string literals

String[] verbs = {"play", "work", "eat", "sleep", "run"};

CSC 1051 M.A. Papalaskari, Villanova University

Page 6: CSC 1051 – Data Structures and Algorithms I

Arrays of Objects• Example: managing a collection of DVD objects

CSC 1051 M.A. Papalaskari, Villanova University

Movies.java

DVD.java

DVDCollection.java

Page 7: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

//********************************************************************// Movies.java Author: Lewis/Loftus//// Demonstrates the use of an array of objects.//********************************************************************

public class Movies{ //----------------------------------------------------------------- // Creates a DVDCollection object and adds some DVDs to it. Prints // reports on the status of the collection. //----------------------------------------------------------------- public static void main (String[] args) { DVDCollection movies = new DVDCollection();

movies.addDVD ("The Godfather", "Francis Ford Coppala", 1972, 24.95, true); movies.addDVD ("District 9", "Neill Blomkamp", 2009, 19.95, false); movies.addDVD ("Iron Man", "Jon Favreau", 2008, 15.95, false); movies.addDVD ("All About Eve", "Joseph Mankiewicz", 1950, 17.50, false); movies.addDVD ("The Matrix", "Andy & Lana Wachowski", 1999, 19.95, true);

System.out.println (movies);

movies.addDVD ("Iron Man 2", "Jon Favreau", 2010, 22.99, false); movies.addDVD ("Casablanca", "Michael Curtiz", 1942, 19.95, false);

System.out.println (movies); }}

Movies.java

Page 8: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

//********************************************************************// Movies.java Author: Lewis/Loftus//// Demonstrates the use of an array of objects.//********************************************************************

public class Movies{ //----------------------------------------------------------------- // Creates a DVDCollection object and adds some DVDs to it. Prints // reports on the status of the collection. //----------------------------------------------------------------- public static void main (String[] args) { DVDCollection movies = new DVDCollection();

movies.addDVD ("The Godfather", "Francis Ford Coppala", 1972, 24.95, true); movies.addDVD ("District 9", "Neill Blomkamp", 2009, 19.95, false); movies.addDVD ("Iron Man", "Jon Favreau", 2008, 15.95, false); movies.addDVD ("All About Eve", "Joseph Mankiewicz", 1950, 17.50, false); movies.addDVD ("The Matrix", "Andy & Lana Wachowski", 1999, 19.95, true);

System.out.println (movies);

movies.addDVD ("Iron Man 2", "Jon Favreau", 2010, 22.99, false); movies.addDVD ("Casablanca", "Michael Curtiz", 1942, 19.95, false);

System.out.println (movies); }}

Output~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~My DVD Collection

Number of DVDs: 5Total cost: $98.30Average cost: $19.66

DVD List:

$24.95 1972 The Godfather Francis Ford Coppala Blu-Ray$19.95 2009 District 9 Neill Blomkamp$15.95 2008 Iron Man Jon Favreau$17.50 1950 All About Eve Joseph Mankiewicz$19.95 1999 The Matrix Andy & Lana Wachowski Blu-Ray

continue

Page 9: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

//********************************************************************// Movies.java Author: Lewis/Loftus//// Demonstrates the use of an array of objects.//********************************************************************

public class Movies{ //----------------------------------------------------------------- // Creates a DVDCollection object and adds some DVDs to it. Prints // reports on the status of the collection. //----------------------------------------------------------------- public static void main (String[] args) { DVDCollection movies = new DVDCollection();

movies.addDVD ("The Godfather", "Francis Ford Coppala", 1972, 24.95, true); movies.addDVD ("District 9", "Neill Blomkamp", 2009, 19.95, false); movies.addDVD ("Iron Man", "Jon Favreau", 2008, 15.95, false); movies.addDVD ("All About Eve", "Joseph Mankiewicz", 1950, 17.50, false); movies.addDVD ("The Matrix", "Andy & Lana Wachowski", 1999, 19.95, true);

System.out.println (movies);

movies.addDVD ("Iron Man 2", "Jon Favreau", 2010, 22.99, false); movies.addDVD ("Casablanca", "Michael Curtiz", 1942, 19.95, false);

System.out.println (movies); }}

Output~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~My DVD Collection

Number of DVDs: 5Total cost: $98.30Average cost: $19.66

DVD List:

$24.95 1972 The Godfather Francis Ford Coppala Blu-Ray$19.95 2009 District 9 Neill Blomkamp$15.95 2008 Iron Man Jon Favreau$17.50 1950 All About Eve Joseph Mankiewicz$19.95 1999 The Matrix Andy & Lana Wachowski Blu-Ray

continue

Output (continued)

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~My DVD Collection

Number of DVDs: 7Total cost: $141.24Average cost: $20.18

DVD List:

$24.95 1972 The Godfather Francis Ford Coppala Blu-Ray$19.95 2009 District 9 Neill Blomkamp$15.95 2008 Iron Man Jon Favreau$17.50 1950 All About Eve Joseph Mankiewicz$19.95 1999 The Matrix Andy & Lana Wachowski Blu-Ray$22.99 2010 Iron Man 2 Jon Favreau$19.95 1942 Casablanca Michael Curtiz

Page 10: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

//********************************************************************// DVDCollection.java Author: Lewis/Loftus//// Represents a collection of DVD movies.//********************************************************************

import java.text.NumberFormat;

public class DVDCollection{ private DVD[] collection; private int count; private double totalCost;

//----------------------------------------------------------------- // Constructor: Creates an initially empty collection. //----------------------------------------------------------------- public DVDCollection () { collection = new DVD[100]; count = 0; totalCost = 0.0; }

continue

DVDCollection.java

Page 11: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

continue

//----------------------------------------------------------------- // Adds a DVD to the collection, increasing the size of the // collection array if necessary. //----------------------------------------------------------------- public void addDVD (String title, String director, int year, double cost, boolean bluRay) { if (count == collection.length) increaseSize();

collection[count] = new DVD (title, director, year, cost, bluRay); totalCost += cost; count++; }

continue

Page 12: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

continue

//----------------------------------------------------------------- // Returns a report describing the DVD collection. //----------------------------------------------------------------- public String toString() { NumberFormat fmt = NumberFormat.getCurrencyInstance();

String report = "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n"; report += "My DVD Collection\n\n";

report += "Number of DVDs: " + count + "\n"; report += "Total cost: " + fmt.format(totalCost) + "\n"; report += "Average cost: " + fmt.format(totalCost/count);

report += "\n\nDVD List:\n\n";

for (int dvd = 0; dvd < count; dvd++) report += collection[dvd].toString() + "\n";

return report; }

continue

Page 13: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

continue

//----------------------------------------------------------------- // Increases the capacity of the collection by creating a // larger array and copying the existing collection into it. //----------------------------------------------------------------- private void increaseSize () { DVD[] temp = new DVD[collection.length * 2];

for (int dvd = 0; dvd < collection.length; dvd++) temp[dvd] = collection[dvd];

collection = temp; }}

Page 14: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

//********************************************************************// DVD.java Author: Lewis/Loftus//// Represents a DVD video disc.//********************************************************************

import java.text.NumberFormat;

public class DVD{ private String title, director; private int year; private double cost; private boolean bluRay;

//----------------------------------------------------------------- // Creates a new DVD with the specified information. //----------------------------------------------------------------- public DVD (String title, String director, int year, double cost, boolean bluRay) { this.title = title; this.director = director; this.year = year; this.cost = cost; this.bluRay = bluRay; }

continue

DVD.java

Page 15: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

continue

//----------------------------------------------------------------- // Returns a string description of this DVD. //----------------------------------------------------------------- public String toString() { NumberFormat fmt = NumberFormat.getCurrencyInstance();

String description;

description = fmt.format(cost) + "\t" + year + "\t"; description += title + "\t" + director;

if (bluRay) description += "\t" + "Blu-Ray";

return description; }}

Page 16: CSC 1051 – Data Structures and Algorithms I

Arrays as Parameters• An entire array can be passed as a parameter to a

method (just like any other object). For example:

CSC 1051 M.A. Papalaskari, Villanova University

• Assumes a definition for method average():

int[] ratings = {4, 3, 3, 1, 4, 3, 1, 0, 3, 4};

average(ratings);

public double average(int[] a){ for (int num: a)

sum += num;return ((double)sum/a.length);

}

Page 17: CSC 1051 – Data Structures and Algorithms I

Try this: Write a method that adds 2 to the value of each element in an array of type double[].

CSC 1051 M.A. Papalaskari, Villanova University

Page 18: CSC 1051 – Data Structures and Algorithms I

Command-Line Arguments• It turns out we have been using arrays as

parameters all along!

public static void main (String[] args)

CSC 1051 M.A. Papalaskari, Villanova University

Page 19: CSC 1051 – Data Structures and Algorithms I

Command-Line Arguments• It turns out we have been using arrays as

parameters all along!

• These values come from command-line arguments that are provided when the interpreter is invoked

• jGrasp calls them “Run Arguments”

CSC 1051 M.A. Papalaskari, Villanova University

public class Test { public static void main (String[] args) { System.out.println (); System.out.println (" " + args[0]); System.out.println (" " + args[1]); }}

Page 20: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

What does it mean to “copy of an array”?• Suppose we have two arrays:

int[] a = {147, 323, 89, 933};int[] b = {100, 200, 300, 400};

for (int i=0; i<a.length; i++)a[i] = b[i];

Page 21: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

Copying elements vs. copying array variables:

• Suppose we have two arrays:int[] a = {147, 323, 89, 933};int[] b = {100, 200, 300, 400};

• Compare the following:

• Now, what is the effect of the following?

a = b;for (int i=0; i<a.length; i++)a[i] = b[i];

a[1] = 1111;b[2] = 2222;

What does it mean to “copy of an array”?

Page 22: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

0 1 2 3a

147 323 89 933

b

1) Copying elements:

for (int i=0; i<a.length; i++)a[i] = b[i];

What changes?

a[1] = 1111;b[2] = 2222;

0 1 2 3

100 200 300 400

Page 23: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

0 1 2 3a

147 323 89 933

b

2) Copying array variables:

a = b;

What changes?

a[1] = 1111;b[2] = 2222;

0 1 2 3

100 200 300 400

Page 24: CSC 1051 – Data Structures and Algorithms I

Two-Dimensional Arrays• A one-dimensional array stores a list of elements

• A two-dimensional array can be thought of as a table of elements, with rows and columns

onedimension

twodimensions

CSC 1051 M.A. Papalaskari, Villanova University

Page 25: CSC 1051 – Data Structures and Algorithms I

Two-Dimensional Arrays• To be precise, in Java a two-dimensional array is

an array of arrays

• A two-dimensional array is declared by specifying the size of each dimension separately:

int[][] table = new int[12][50];

• A array element is referenced using two index values:

value = table[3][6]

• The array stored in one row can be specified using one index

CSC 1051 M.A. Papalaskari, Villanova University

Page 26: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

0 1 2 9.3 5.8 6.9 5.5 9.0 8.3 7.7 9.2 9.8 8.2

0 1 2 3 4 5 6 7 8 9

8.9 8.0 8.4 6.2 7.7 7.3 9.6 6.1 7.8 7.3

0 1 2 3 4 5 6 7 8 9

7.9 8.7 9.4 8.2 6.7 9.8 8.7 8.1 7.4 9.1

courseGrade[1][4] 2D array element

array element (a row)

courseGrade

0 1 2 3 4 5 6 7 8 9

courseGrade[2]

2D Arrays - Overview

double[][] courseGrade = new double[3][10]; declaration

Page 27: CSC 1051 – Data Structures and Algorithms I

Two-Dimensional Arrays

• See TwoDArray.java

• See SodaSurvey.java

CSC 1051 M.A. Papalaskari, Villanova University

Expression Type Description

table int[][] 2D array of integers, orarray of integer arrays

table[5] int[] array of integers

table[5][12] int integer

Page 28: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

//********************************************************************// TwoDArray.java Author: Lewis/Loftus//// Demonstrates the use of a two-dimensional array.//********************************************************************

public class TwoDArray{ //----------------------------------------------------------------- // Creates a 2D array of integers, fills it with increasing // integer values, then prints them out. //----------------------------------------------------------------- public static void main (String[] args) { int[][] table = new int[5][10];

// Load the table with values for (int row=0; row < table.length; row++) for (int col=0; col < table[row].length; col++) table[row][col] = row * 10 + col;

// Print the table for (int row=0; row < table.length; row++) { for (int col=0; col < table[row].length; col++) System.out.print (table[row][col] + "\t"); System.out.println(); } }}

Page 29: CSC 1051 – Data Structures and Algorithms I

CSC 1051 M.A. Papalaskari, Villanova University

//********************************************************************// TwoDArray.java Author: Lewis/Loftus//// Demonstrates the use of a two-dimensional array.//********************************************************************

public class TwoDArray{ //----------------------------------------------------------------- // Creates a 2D array of integers, fills it with increasing // integer values, then prints them out. //----------------------------------------------------------------- public static void main (String[] args) { int[][] table = new int[5][10];

// Load the table with values for (int row=0; row < table.length; row++) for (int col=0; col < table[row].length; col++) table[row][col] = row * 10 + col;

// Print the table for (int row=0; row < table.length; row++) { for (int col=0; col < table[row].length; col++) System.out.print (table[row][col] + "\t"); System.out.println(); } }}

Output0 1 2 3 4 5 6 7 8 910 11 12 13 14 15 16 17 18 1920 21 22 23 24 25 26 27 28 2930 31 32 33 34 35 36 37 38 3940 41 42 43 44 45 46 47 48 49

Page 30: CSC 1051 – Data Structures and Algorithms I

Multidimensional Arrays• An array can have many dimensions – if it has

more than one dimension, it is called a multidimensional array

• Each dimension subdivides the previous one into the specified number of elements

• Each dimension has its own length constant

• Because each dimension is an array of array references, the arrays within one dimension can be of different lengths

– these are sometimes called ragged arrays

CSC 1051 M.A. Papalaskari, Villanova University