CS 116: Object Oriented Programming II. Topics Vectors Multidimensional Arrays ArrayList.

Slides:



Advertisements
Similar presentations
Arrays.
Advertisements

Arrays.
Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Java Software Solutions Foundations of Program Design Sixth Edition by Lewis.
Loops Notes adapted from Dr. Flores. It repeats a set of statements while a condition is true. while (condition) { execute these statements; } “while”
Chapter 7 Arrays. © 2004 Pearson Addison-Wesley. All rights reserved7-2 Arrays Arrays are objects that help us organize large amounts of information Chapter.
1 Arrays b An array is an ordered list of values An array of size N is indexed from zero to N-1 scores.
©2004 Brooks/Cole Chapter 8 Arrays. Figures ©2004 Brooks/Cole CS 119: Intro to JavaFall 2005 Sometimes we have lists of data values that all need to be.
Chapter 8. 2 Objectives You should be able to describe: One-Dimensional Arrays Array Initialization Arrays as Arguments Two-Dimensional Arrays Common.
1 Arrays  Arrays are objects that help us organize large amounts of information  Chapter 8 focuses on: array declaration and use passing arrays and array.
1 Chapter 2 Introductory Programs. 2 Getting started To create and run a Java program –Create a text file with a.java extension for the source code. For.
CS102--Object Oriented Programming Lecture 6: – The Arrays class – Multi-dimensional arrays Copyright © 2008 Xiaoyan Li.
Aalborg Media Lab 28-Jun-15 Software Design Lecture 8 “Arrays”
Arrays, Loops weeks 4-6 (change from syllabus for week 6) Chapter 4.
Arrays in Java Selim Aksoy Bilkent University Department of Computer Engineering
C++ for Engineers and Scientists Third Edition
Chapter 10 2D Arrays Collection Classes. Topics Arrays with more than one dimension Java Collections API ArrayList Map.
© 2011 Pearson Education, publishing as Addison-Wesley 1 Arrays  Arrays are objects that help us organize large amounts of information  Chapter 6 focuses.
Chapter 7: Arrays. In this chapter, you will learn about: One-dimensional arrays Array initialization Declaring and processing two-dimensional arrays.
A First Book of ANSI C Fourth Edition
By Nicholas Policelli An Introduction to Java. Basic Program Structure public class ClassName { public static void main(String[] args) { program statements.
ArrayList, Multidimensional Arrays
 2008 Pearson Education, Inc. All rights reserved JavaScript: Arrays.
Arrays Part 9 dbg. Arrays An array is a fixed number of contiguous memory locations, all containing data of the same type, identified by one variable.
JAVA: An Introduction to Problem Solving & Programming, 5 th Ed. By Walter Savitch and Frank Carrano. ISBN © 2009 Pearson Education, Inc., Upper.
 Pearson Education, Inc. All rights reserved Arrays.
Arrays Module 6. Objectives Nature and purpose of an array Using arrays in Java programs Methods with array parameter Methods that return an array Array.
Java Programming: From Problem Analysis to Program Design, 4e
© 2007 Lawrenceville Press Slide 1 Chapter 10 Arrays  Can store many of the same kind of data together  Allows a collection of related values to be stored.
Object-Oriented Program Development Using Java: A Class-Centered Approach, Enhanced Edition.
Chapter 8: Collections: Arrays. 2 Objectives One-Dimensional Arrays Array Initialization The Arrays Class: Searching and Sorting Arrays as Arguments The.
Chapter 9 Multidimensional Arrays and the ArrayList Class.
Arrays BCIS 3680 Enterprise Programming. Overview 2  Array terminology  Creating arrays  Declaring and instantiating an array  Assigning value to.
Java SE 8 for Programmers, Third Edition
ARRAYS Computer Engineering Department Java Course Asst. Prof. Dr. Ahmet Sayar Kocaeli University - Fall
8-1 Chapter 8: Arrays Arrays are objects that help us organize large amounts of information Today we will focuses on: –array declaration and use –bounds.
M180: Data Structures & Algorithms in Java Arrays in Java Arab Open University 1.
C++ for Engineers and Scientists Second Edition Chapter 11 Arrays.
OBJECTS FOR ORGANIZING DATA -- As our programs get more sophisticated, we need assistance organizing large amounts of data. : array declaration and use.
Chapter overview This chapter focuses on Array declaration and use Bounds checking and capacity Arrays storing object references Variable length parameter.
ArrayList Class An ArrayList is an object that contains a sequence of elements that are ordered by position. An ArrayList is an object that contains a.
A First Book of C++: From Here To There, Third Edition2 Objectives You should be able to describe: One-Dimensional Arrays Array Initialization Arrays.
CMSC 202 Arrays 2 nd Lecture. Aug 6, Array Parameters Both array indexed variables and entire arrays can be used as arguments to methods –An indexed.
Chapter 8 Arrays. A First Book of ANSI C, Fourth Edition2 Introduction Atomic variable: variable whose value cannot be further subdivided into a built-in.
Java Software Solutions Lewis and Loftus Chapter 6 1 Copyright 1997 by John Lewis and William Loftus. All rights reserved. Objects for Organizing Data.
JAVA: An Introduction to Problem Solving & Programming, 5 th Ed. By Walter Savitch and Frank Carrano. ISBN © 2008 Pearson Education, Inc., Upper.
CS 116 OBJECT ORIENTED PROGRAMMING II LECTURE 5 GEORGE KOUTSOGIANNAKIS Copyright: 2016 Illinois Institute of Technology/George Koutsogiannakis 1.
Arrays Chapter 7. MIS Object Oriented Systems Arrays UTD, SOM 2 Objectives Nature and purpose of an array Using arrays in Java programs Methods.
Chapter 8 Slides from GaddisText Arrays of more than 1 dimension.
Arrays (part 2) 1 -Based on slides from Deitel & Associates, Inc. - Revised by T. A. Yang.
Multidimensional Arrays tMyn1 Multidimensional Arrays It is possible to declare arrays that require two or more separate index values to access an element.
Arrays Declaring arrays Passing arrays to functions Searching arrays with linear search Sorting arrays with insertion sort Multidimensional arrays Programming.
C++ Array 1. C++ provides a data structure, the array, which stores a fixed-size sequential collection of elements of the same type. An array is used.
CS 115 OBJECT ORIENTED PROGRAMMING I LECTURE 11 GEORGE KOUTSOGIANNAKIS 1 Copyright: 2015 Illinois Institute of Technology_ George Koutsogiannakis.
 2005 Pearson Education, Inc. All rights reserved Arrays.
CS 116 OBJECT ORIENTED PROGRAMMING II LECTURE 6 GEORGE KOUTSOGIANNAKIS Copyright: 2016 Illinois Institute of Technology/George Koutsogiannakis 1.
VISUAL C++ PROGRAMMING: CONCEPTS AND PROJECTS Chapter 7A Arrays (Concepts)
Chapter 9 Introduction to Arrays Fundamentals of Java.
Arrays Chap. 9 Storing Collections of Values 1. Introductory Example Problem: Teachers need to be able to compute a variety of grading statistics for.
KUKUM-06/07 EKT120: Computer Programming 1 Week 6 Arrays-Part 1.
LESSON 8: INTRODUCTION TO ARRAYS. Lesson 8: Introduction To Arrays Objectives: Write programs that handle collections of similar items. Declare array.
OBJECT ORIENTED PROGRAMMING II LECTURE 15 GEORGE KOUTSOGIANNAKIS
Java How to Program, Late Objects Version, 10/e
Can store many of the same kind of data together
Introduction To Programming Information Technology , 1’st Semester
Can store many of the same kind of data together
Object Oriented Programming in java
OBJECT ORIENTED PROGRAMMING II LECTURE 13_2 GEORGE KOUTSOGIANNAKIS
Can store many of the same kind of data together
OBJECT ORIENTED PROGRAMMING I LECTURE 11 GEORGE KOUTSOGIANNAKIS
Arrays.
Presentation transcript:

CS 116: Object Oriented Programming II

Topics Vectors Multidimensional Arrays ArrayList

Vectors Using vectors could be better than using arrays in some cases: Vectors can adjust their size dynamically. Ideal for cases where we don’t know the size of thedata involved. Vector class is part of the java.util package. Vectors accept only Object data types. You can not insert primitive data types. When reading the object from the vector you have to type casted back to the Class that the object belongs to. Vectors are easier to sort, search,remove elements, or add elements than arrays. The same vector object can object multiple object types (i.e. Auto, Student, Person objects). This is something that arrays can not do. 3

Vectors Vector v=new Vector(); Constructs a vector of default size 10. Size will be incremented as needed. Notice that the class has other constructors also. Auto car1=new Auto(); v.addElement(car1) ; adds the object car1 to the end of the vector and increases its size by 1. Object mycarobj=v.elementAt(i); Auto mycar=(Auto)mycarobj; returns the object stored at index i. Notice that it is a two step process: First we retrieve the object as a generalized Object type. Then we type casted to the specific object type (we have to know what the object type is). 4

Vectors v.remove(i); removes the element at index i. adjusts the size of the vector. v.set(int i, Object obj); replaces the object stored originally at index i with the new object obj. v.add(int i, Object obj) sets the object obj at index i. Pushes the existing object at index I,and everything else after it, one position down in the vector. It increases the size of the vector by 1. 5

Vectors-Example import java.util.*; public class UseVectors {public static void main(String[] args) { Vector v=new Vector(); VehicleA car1=new VehicleA(); VehicleA car2=new VehicleA(); v.addElement(car1); v.addElement(car2); Object o1=v.elementAt(0); VehicleA veh1=(VehicleA)o1; veh1.setDistance(5.0); System.out.println(veh1.toString()); //place it back in the same index after updating its attribute distance v.set(o, veh1); } 6

7 Constructor Summary VectorVector() Constructs an empty vector so that its internal data array has size 10 and its standard capacity increment is zero. VectorVector(int initialCapacity) Constructs an empty vector with the specified initial capacity and with its capacity increment equal to zero. VectorVector(int initialCapacity, int capacityIncrement) Constructs an empty vector with the specified initial capacity and capacity increment.

8 Some of the available Methods (see API for complete listing) boolean addadd(E e) Appends the specified element to the end of this Vector.E void addadd(int index, E element) Inserts the specified element at the specified position in this Vector.E void clearclear() Removes all of the elements from this Vector. EE (where E is the specific Object type stored) elementAtelementAt(int index) Returns the component at the specified index. void addElementaddElement(E obj) Adds the specified component to the end of this vector, increasing its size by oneE E (where E is the specific Object type stored) setset(int index, E element) Replaces the element at the specified position in this Vector with the specified element.E

Multidimensional Arrays Two-Dimensional Arrays Allows organization of data in rows and columns in a table-like representation Example: Daily temperatures can be arranged as 52 weeks with 7 days each. 9

Declaring Multidimensional Arrays Declaring a two-dimensional array: datatype [][] arrayName; or datatype [][] arrayName1, arrayName2, …; Declaring a three-dimensional array: datatype [][][] arrayName; or datatype [][][] arrayName1, arrayName2, …; Examples: double [][] dailyTemps, weeklyTemps; Auto [][][] cars; 10 Two empty braces indicates it is a 2 Dim array Array of objects We are not done! Need to instantiate the array!!

Instantiating Multidimensional Arrays Instantiating a two-dimensional array: arrayName = new datatype [exp1][exp2]; where exp1 and exp2 are expressions that evaluate to integers and specify, respectively, the number of rows and the number of columns in the array. Example: dailyTemps = new double [52][7]; dailyTemps has 52 rows and 7 columns, for a total of 364 elements. 11 Use this way to instantiate only when all rows have the same no. of columns Rows in an array can have different no. of columns

Assigning Initial Values datatype [][] arrayName = { { value00, value01, … }, { value10, value11, …}, … }; where valueMN is an expression that evaluates to the data type of the array and is the value to assign to the element at row M and column N. The number of sublists is the number of rows in the array. The number of values in each sublist determines the number of columns in that row. Thus, a two-dimensional array can have a different number of columns in each row. Note that each {…… } separated by coma represents one row’s data. 12

Assigning Initial Values Example For example, this statement: int [][] numbersList1 = { { 0, 5, 10 }, { 0, 3, 6, 9 } }; 13 Actually an array of arrays! Each reference points to another single dimensional array Reference to 1D array Each reference points to the actual value or object

An Array of Arrays As the preceding figure illustrates, a two-dimensional array is an array of arrays. The first dimension of a two-dimensional array is an array of array references, with each reference pointing to a single-dimensional array. Thus, a two-dimensional array is comprised of an array of rows, where each row is a single-dimensional array. 14

Instantiating Arrays with Different Length Rows To instantiate a two-dimensional array whose rows have a different number of columns: 1. instantiate the two-dimensional array 2. instantiate each row as a single-dimensional array //instantiate the array with 3 rows char [][] grades = new char [3][]; // instantiate each row grades[0] = new char [23]; // instantiate row 0 grades[1] = new char [16]; // instantiate row 1 grades[2] = new char [12]; // instantiate row 2 15

Accessing Array Elements Elements of a two-dimensional array are accessed using this syntax: arrayName[exp1][exp2] exp1 is the element's row index row index of first row: 0 row index of last row: number of rows - 1 exp2 is the element's column index column index of first column: 0 column index of last column: number of columns in that row

The Length of the Array The number of rows in a two-dimensional array is: arrayName.length The number of columns in row n in a two-dimensional array is: arrayName[n].length 17

Instantiating Arrays with Different Length Rows //instantiate the array with 3 rows char [][] grades = new char [3][]; // instantiate each row grades[0] = new char [23]; // instantiate row 0 grades[1] = new char [16]; // instantiate row 1 grades[2] = new char [12]; // instantiate row 2 18 grades.length gives you the number of rows grades[0].length gives you the number of cols in row 0 (23 in this example)

2 Dimensional Arrays of objects After instantiating the 2 Dim arrays, we need to instantiate the objects for each position in the array Only when are dealing with array of objects not for primitive data types To instantiate all array objects, we use a nested for loop: Auto [][] cars = new Auto [3][]; cars[0] = new Auto [23]; // instantiate row 0 cars[1] = new Auto [16]; // instantiate row 1 cars[2] = new Auto [12]; // instantiate row 2 for ( int i = 0; i < arrayName.length; i++ ){ for ( int j = 0; j < arrayName[i].length; j++ ){ cars[i][j] = new Auto(); }

Accessing Two-Dimensional Array Elements Array elementSyntax Row 0, column j arrayName[0][j] Row i, column j arrayName[i][j] Last row, column j arrayName[arrayName.length – 1][j] Last row, last column arrayName[arrayName.length – 1] [arrayName [arrayName.length -1].length – 1] Number of rows arrayName.length Number of columns in row i arrayName[i].length 20

Output all the elements of a two- dimensional array To process all array elements in row order, we use a nested for loop: for ( int i = 0; i < arrayName.length; i++ ) { for ( int j = 0; j < arrayName[i].length; j++ ) { // process element arrayName[i][j] } The outer loop processes the rows. The inner loop processes the columns within each row. See Example 9.3 OutputFamilyCellBills.java 21 By using length attribute of the array, we take care of rows with different columns

Processing a Given Row Suppose we had an array where the rows represent months of the year and columns represent the various categories of expenditures (i.e. CarExpenses, FoodExpenses, RestaurantExpenses, etc.) If we want a listing of the expenses for a particular month then we need to process one row only (the row that represents the month). To process just row i, we use this standard form: for ( int j = 0; j < arrayName[i].length; j++ ) { // process element arrayName[i][j] } Notice that we iterate through the elements of the row column by column where a column is identified by j. Also notice that arrayName[i].length returns the size of the array that represents that particular row (ith row). 22

Processing a Given Column If we want to list all the expenditures for the whole year for a particular type of an expenditure (i.e. FoodExpenses) then we need to process just one column. To process just column j, we use this standard form: for ( int i = 0; i < arrayName.length; i++ ) { // code to process element arrayName[i][j] } Note: Because rows have variable lengths, we must verify that the current row has a column j before attempting to process the element. Also notice that arrayName.length returns the number of rows of the array 23

Arrays where not all columns have the same size Suppose we want to store test grades for three courses. Each course has a different number of tests, so each row has a different number of columns: int [][] grades = { { 89, 75 }, { 84, 76, 92, 96 }, { 80, 88, 95 } }; First, we need to find the number of columns in the largest row. We use that in our loop condition. Then, before attempting to process the array element, we check whether the given column exists in the current row. 24

Arrays where not all rows have the same number of columns Suppose that we have stored the maximum number of columns in maxNumberOfColumns; the general pattern for processing elements one column at a time is: for ( int j = 0; j < maxNumberOfColumns; j++ ) { for ( int i = 0; i < arrayName.length; i++ ) { // does column j exist in this row? if ( j < arrayName[i].length ) { // process element arrayName[i][j] } Notice that this is different than slide “Processing a Given Column”. Here we scan through every column, and process each column one by one. 25

Arrays where not all rows have the same number of columns Therefore first we scan column 0 to get values 0, 0 Next column 1 to get 5, 3 Next column 2 to get 10,6 Next column 4 but this column does not hav e row 0 therefore only row 1 has the value 9. In other words array[0].length returns 3 and when j=4 if(j<aarray[i].length) returns false. 26

Practice problem Download MultDimPrac.zip from the course website Modify the “twoDimPrac.java”

Other Multidimensional Arrays If we want to keep track of sales on a per-year, per-week, and per-day basis, we could use a three-dimensional array: 1 st dimension: year 2 nd dimension: week 3 rd dimension: day of the week 28

Sample Code // declare a three-dimensional array double [][][] sales; // instantiate the array for 10 years, 52 weeks, // and 7 days sales = new double [10][52][7]; // set the value of the first element sales[0][0][0] = ; // set the value for year 4, week 22, day 3 sales [4][22][3] = ; // set the last value in the array sales [9][51][6] = ; 29

Instantiating a 3-Dim Array [0] [1] [2] [3] [0][0][0][1][0][2] [1][0][1][1][1][2][0][3] [2][0][2][1][2][2] [3][0][3][1][3][2][3][3][3][4] [0][0][0][0][0][1][0][0][2][0][0][3] [0][1][0][0][1][1][0][1][2] [0][2][0] References to 1D arrays References to actual data (primitive data types or objects)

Practice problem Modify the “threeDimPrac.java” in MultDimPrac.zip from the course website

Code to Print the sales Array for ( int i = 0; i < sales.length; i++ ) { for ( int j = 0; j < sales[i].length; j++ ) { for ( int k = 0; k < sales[i][j].length; k++ ) { // print the element at sales[i][j][k] System.out.print( sales[i][j][k] + "\t" ); } // skip a line after each week System.out.println( ); } // skip a line after each month System.out.println( ); } 32

General Pattern for Processing a Three- Dimensional Array for ( int i = 0; i < arrayName.length; i++ ) { for ( int j = 0; j < arrayName[i].length; j++ ) { for ( int k = 0; k <arrayName[i][j].length; k++ ) { // process the element arrayName[i][j][k] } 33

A Four-Dimensional Array If we want to keep track of sales on a per-state, per-year, per-week, and per-day basis, we could use a four-dimensional array: 1 st dimension: state 2 nd dimension: year 3 rd dimension: week 4 th dimension: day of the week 34

General Pattern for Processing a Four-Dimensional Array for ( int i = 0; i < arrayName.length; i++ ) { for ( int j = 0; j < arrayName[i].length; j++ ) { for ( int k = 0; k < arrayName[i][j].length; k++ ) { for ( int l = 0; l < arrayName[i][j][k].length; l++ ) { // process element arrayName[i][j][k][l] } 35

The ArrayList Class Arrays have a fixed size once they have been instantiated. What if we don't know how many elements we will need? For example, if we are reading values from a file returning search results We could create a very large array, but then we waste space for all unused elements. A better idea is to use an ArrayList, which stores elements of object references and automatically expands its size, as needed. 36

The ArrayList Class The ArrayList class is in the package: java.util All ArrayList elements are object references, so we could have an ArrayList of Auto objects, Book objects, Strings, etc. To store primitive types in an ArrayList, use the wrapper classes (Integer, Double, Character, Boolean, etc.) The ArrayList is a generic class. The ArrayList class has been written so that it can store object references of any type specified by the client. 37

Declaring an ArrayList Use this syntax: ArrayList arrayListName; E is a class name that specifies the type of object references that will be stored in the ArrayList. Example: ArrayList listOfStrings; ArrayList listOfCars; ArrayList listOfInts; 38

ArrayList Constructors The capacity of an ArrayList is the total number of elements allocated to the list. The size of an an ArrayList is the number of elements that are used. Constructor name and argument list ArrayList constructs an ArrayList object of type E with an initial capacity of 10 ArrayList ( int initialCapacity ) constructs an ArrayList object of type E with the specified initial capacity

Instantiating an ArrayList This list has a capacity of 10 Astronaut references (default capacity), but a size of 0. ArrayList listOfAstronauts = new ArrayList ( ); This list has a capacity of 5 Strings, but a size of 0. ArrayList listOfStrings = new ArrayList ( 5 ); 40

ArrayList Methods Return valueMethod name and argument list booleanadd( E element ) appends element to the end of the list voidclear( ) removes all the elements in the list intsize( ) returns the number of elements in the list Eremove( int index ) removes the element at the specified index position

More ArrayList Methods Return valueMethod name and argument list Eget( int index ) returns the element at the specified index position; the element is not removed from the list. Eset( int index, E element ) replaces the element at the specified index position with the specified element voidtrimToSize( ) sets the capacity of the list to its current size

Processing Array Lists Using a standard for loop: ClassName currentObject; for ( int i = 0; i < arrayListName.size( ); i++ ) { currentObject = arrayListName.get( i ); // process currentObject } Example: Auto currentAuto; for ( int i = 0; i < listOfAutos.size( ); i++ ) { currentAuto = listOfAutos.get( i ); // process currentAuto } 43

Processing Array Lists Example of a method definition that returns an ArrayList: public ArrayList myMethod() Example of setting an object into the list: ArrayList list=new ArrayList (); list.set(0, obj); //sets at index 0 the object obj 44

The Enhanced for Loop Simplifies processing of lists The standard form is: for ( ClassName currentObject : arrayListName ) { // process currentObject } This enhanced for loop prints all elements of an ArrayList of Strings named list: for ( String s : list ) { System.out.println( s ); } 45