 2005 Pearson Education, Inc. All rights reserved. 1 7 7 Arrays.

Slides:



Advertisements
Similar presentations
Arrays.
Advertisements

 2006 Pearson Education, Inc. All rights reserved Arrays.
 2003 Prentice Hall, Inc. All rights reserved. 7.1 Introduction Arrays –Data structures which reference one or more value –All items must have same data.
5 5 Arrays. OBJECTIVES In this lecture we will learn:  Case switch  To use the array data structure to represent a set of related data items.  To declare.
Arrays  Writing a program that uses a large amount of information.  Such as a list of 100 elements.  It is not practical to declare.
Introduction to Computers and Programming Lecture 16: Arrays (cont) Professor: Evan Korth New York University.
Arrays Chapter 6.
 2003 Prentice Hall, Inc. All rights reserved. Chapter 7 - Arrays Outline 7.1 Introduction 7.2 Arrays 7.3 Declaring and Creating Arrays 7.4 Examples Using.
 2005 Pearson Education, Inc. All rights reserved Arrays.
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.
 2006 Pearson Education, Inc. All rights reserved Arrays.
Chapter 6 C Arrays Acknowledgment The notes are adapted from those provided by Deitel & Associates, Inc. and Pearson Education Inc. Arrays are data structures.
 2003 Prentice Hall, Inc. All rights reserved. Modified for use with this course. Introduction to Arrays Introduction to Computers and Programming in.
C++ for Engineers and Scientists Third Edition
1 CSCE 1030 Computer Science 1 Arrays Chapter 7 in Small Java.
 2007 Pearson Education, Inc. All rights reserved C Arrays.
 2006 Pearson Education, Inc. All rights reserved Arrays and Vectors.
 Pearson Education, Inc. All rights reserved Arrays.
 2006 Pearson Education, Inc. All rights reserved Arrays and Vectors.
Visual Basic 2010 How to Program © by Pearson Education, Inc. All Rights Reserved.
 2004 Prentice Hall, Inc. All rights reserved. 1 Chapter 11 - JavaScript: Arrays Outline 11.1 Introduction 11.2 Arrays 11.3 Declaring and Allocating Arrays.
 2006 Pearson Education, Inc. All rights reserved Arrays.
CHAPTER 07 Arrays and Vectors (part I). OBJECTIVES 2 In this part you will learn:  To use the array data structure to represent a set of related data.
Arrays Chapter 7. 2 "All students to receive arrays!" reports Dr. Austin. Declaring arrays scores : Inspecting.
 2008 Pearson Education, Inc. All rights reserved JavaScript: Arrays.
 2005 Pearson Education, Inc. All rights reserved. 1 Arrays Part 4.
ARRAYS 1 Week 2. Data Structures  Data structure  A particular way of storing and organising data in a computer so that it can be used efficiently 
 Pearson Education, Inc. All rights reserved Arrays.
JAVA: An Introduction to Problem Solving & Programming, 5 th Ed. By Walter Savitch and Frank Carrano. ISBN © 2009 Pearson Education, Inc., Upper.
 2005 Pearson Education, Inc. All rights reserved. 1 Arrays.
 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.
Hello.java Program Output 1 public class Hello { 2 public static void main( String [] args ) 3 { 4 System.out.println( “Hello!" ); 5 } // end method main.
Chapter 7 Arrays. A 12-element array Declaring and Creating Arrays Arrays are objects that occupy memory Created dynamically with keyword new int c[]
1 © 2002, Cisco Systems, Inc. All rights reserved. Arrays Chapter 7.
Java Script: Arrays (Chapter 11 in [2]). 2 Outline Introduction Introduction Arrays Arrays Declaring and Allocating Arrays Declaring and Allocating Arrays.
Arrays Array – Group of contiguous memory locations Each memory location has same name Each memory location has same type.
Java™ How to Program, 9/e © Copyright by Pearson Education, Inc. All Rights Reserved.
 2005 Pearson Education, Inc. All rights reserved Arrays.
 2008 Pearson Education, Inc. All rights reserved Arrays and Vectors.
 2006 Pearson Education, Inc. All rights reserved Arrays.
Week # 2: Arrays.  Data structure  A particular way of storing and organising data in a computer so that it can be used efficiently  Types of data.
 Pearson Education, Inc. All rights reserved Arrays.
 2007 Pearson Education, Inc. All rights reserved C Arrays.
 2008 Pearson Education, Inc. All rights reserved. 1 Arrays and Vectors.
 Pearson Education, Inc. All rights reserved Arrays.
T U T O R I A L  2009 Pearson Education, Inc. All rights reserved Student Grades Application Introducing Two-Dimensional Arrays and RadioButton.
JAVA: An Introduction to Problem Solving & Programming, 5 th Ed. By Walter Savitch and Frank Carrano. ISBN © 2008 Pearson Education, Inc., Upper.
Arrays Chapter 7. 2 Declaring and Creating Arrays Recall that an array is a collection of elements all of the _____________ Array objects in Java must.
Arrays Chapter 7. MIS Object Oriented Systems Arrays UTD, SOM 2 Objectives Nature and purpose of an array Using arrays in Java programs Methods.
 Pearson Education, Inc. All rights reserved Passing Arrays to Methods To pass array argument to a method – Specify array name without.
Arrays (part 2) 1 -Based on slides from Deitel & Associates, Inc. - Revised by T. A. Yang.
Arrays Declaring arrays Passing arrays to functions Searching arrays with linear search Sorting arrays with insertion sort Multidimensional arrays Programming.
SEQUENTIAL AND OBJECT ORIENTED PROGRAMMING Arrays.
 2008 Pearson Education, Inc. All rights reserved JavaScript: Arrays.
 2008 Pearson Education, Inc. All rights reserved Arrays and Vectors.
 2006 Pearson Education, Inc. All rights reserved Arrays and Vectors.
A DVANCED P ROGRAMMING C HAPTER 8: A RRAYS Dr Shahriar Bijani Spring 2016.
Lecture 4: Chapter 7 - Arrays Outline Declaring and Creating Arrays Examples Using Arrays References and Reference Parameters Passing Arrays to Methods.
Arrays Chapter 7.
© 2016 Pearson Education, Ltd. All rights reserved.
8 Arrays.
Java How to Program, Late Objects Version, 10/e
7 Arrays.
7 Arrays.
7 Arrays.
Introduction To Programming Information Technology , 1’st Semester
Object Oriented Programming in java
MSIS 655 Advanced Business Applications Programming
Arrays Chapter 7.
Presentation transcript:

 2005 Pearson Education, Inc. All rights reserved Arrays

 2005 Pearson Education, Inc. All rights reserved. 2 Fig. 7.1 | A 12-element array.

 2005 Pearson Education, Inc. All rights reserved Arrays (Cont.) Index – Also called subscript – Position number in square brackets – Must be positive integer or integer expression – First element has index zero a = 5; b = 6; c[ a + b ] += 2; Adds 2 to c[ 11 ]

 2005 Pearson Education, Inc. All rights reserved. 4 Common Programming Error 7.1 Using a value of type long as an array index results in a compilation error. An index must be an int value or a value of a type that can be promoted to int—namely, byte, short or char, but not long.

 2005 Pearson Education, Inc. All rights reserved Arrays (Cont.) Examine array c – c is the array name – c.length accesses array c ’s length – c has 12 elements ( c[0], c[1], … c[11] ) The value of c[0] is –45

 2005 Pearson Education, Inc. All rights reserved Declaring and Creating Arrays Declaring and Creating arrays – Arrays are objects that occupy memory – Created dynamically with keyword new int c[] = new int[ 12 ]; – Equivalent to int c[]; // declare array variable c = new int[ 12 ]; // create array We can create arrays of objects too String b[] = new String[ 100 ];

 2005 Pearson Education, Inc. All rights reserved. 7 Common Programming Error 7.2 In an array declaration, specifying the number of elements in the square brackets of the declaration (e.g., int c[ 12 ];) is a syntax error.

 2005 Pearson Education, Inc. All rights reserved. 8 Outline InitArray.java Line 8 Declare array as an array of ints Line 10 Create 10 ints for array; each int is initialized to 0 by default Line 15 array.length returns length of array Line 16 array[counter] returns int associated with index in array Program output

 2005 Pearson Education, Inc. All rights reserved Examples Using Arrays (Cont.) Using an array initializer – Use initializer list Items enclosed in braces ( {} ) Items in list separated by commas int n[] = { 10, 20, 30, 40, 50 }; – Creates a five-element array – Index values of 0, 1, 2, 3, 4 – Do not need keyword new

 2005 Pearson Education, Inc. All rights reserved. 10 Outline InitArray.java Line 9 Declare array as an array of ints Line 9 Compiler uses initializer list to allocate array Program output

 2005 Pearson Education, Inc. All rights reserved. 11 Outline InitArray.java Line 8 Declare constant variable Line 9 Declare and create array that contains 10 ints Line 13 Use array index to assign array Program output

 2005 Pearson Education, Inc. All rights reserved. 12 Outline SumArray.java Line 8 Declare array with initializer list Lines Sum all array values Program output

 2005 Pearson Education, Inc. All rights reserved. 13 Outline BarChart.java (1 of 2) Line 8 Declare array with initializer list Line 19 Use the 0 flag to display one- digit grade with a leading 0 Lines For each array element, print associated number of asterisks

 2005 Pearson Education, Inc. All rights reserved. 14 Outline BarChart.java (2 of 2) Program output

 2005 Pearson Education, Inc. All rights reserved. 15 Outline RollDie.java Line 10 Declare frequency as array of 7 ints Lines Generate 6000 random integers in range 1-6 Line 14 Increment frequency values at index associated with random number Program output

 2005 Pearson Education, Inc. All rights reserved. 16 Outline StudentPoll.java (1 of 2) Lines 9-11 Declare responses as array to store 40 responses Line 12 Declare frequency as array of 11 int and ignore the first element Lines For each response, increment frequency values at index associated with that response

 2005 Pearson Education, Inc. All rights reserved. 17 Outline StudentPoll.java (2 of 2) Program output

 2005 Pearson Education, Inc. All rights reserved. 18 Error-Prevention Tip 7.1 An exception indicates that an error has occurred in a program. A programmer often can write code to recover from an exception and continue program execution, rather than abnormally terminating the program. When a program attempts to access an element outside the array bounds, an ArrayIndexOutOfBoundsException occurs. Exception handling is discussed in Chapter 13.

 2005 Pearson Education, Inc. All rights reserved. 19 Error-Prevention Tip 7.2 When writing code to loop through an array, ensure that the array index is always greater than or equal to 0 and less than the length of the array. The loop-continuation condition should prevent the accessing of elements outside this range.

 2005 Pearson Education, Inc. All rights reserved Case Study: Card Shuffling and Dealing Simulation Program simulates card shuffling and dealing – Use random number generation – Use an array of reference type elements to represent cards – Three classes Card – Represent a playing card DeckOfCards – Represent a deck of 52 playing cards DeckOfCardsTest – Demonstrate card shuffling and dealing

 2005 Pearson Education, Inc. All rights reserved. 21 Outline Card.java Lines 17-20

 2005 Pearson Education, Inc. All rights reserved. 22 Outline DeckOfCards.java (1 of 2) Line 7 Line 9 Lines Line 17 Lines 24-26

 2005 Pearson Education, Inc. All rights reserved. 23 Outline DeckOfCards.java (2 of 2) Lines Line 52

 2005 Pearson Education, Inc. All rights reserved. 24 Outline DeckOfCardsTest.java (1 of 2)

 2005 Pearson Education, Inc. All rights reserved. 25 Outline DeckOfCardsTest.java (2 of 2)

 2005 Pearson Education, Inc. All rights reserved Enhanced for Statement Enhanced for statement – New feature of J2SE 5.0 – Allows iterates through elements of an array or a collection without using a counter – Syntax for ( parameter : arrayName ) statement

 2005 Pearson Education, Inc. All rights reserved. 27 Outline EnhancedForTest.java

 2005 Pearson Education, Inc. All rights reserved Enhanced for Statement (Cont.) Lines are equivalent to for ( int counter = 0; counter < array.length; counter++ ) total += array[ counter ]; Usage – Can access array elements – Cannot modify array elements – Cannot access the counter indicating the index

 2005 Pearson Education, Inc. All rights reserved Passing Arrays to Methods To pass array argument to a method – Specify array name without brackets Array hourlyTemperatures is declared as int hourlyTemperatures = new int[ 24 ]; The method call modifyArray( hourlyTemperatures ); Passes array hourlyTemperatures to method modifyArray

 2005 Pearson Education, Inc. All rights reserved. 30 Outline PassArray.java (1 of 2) Line 9 Line 19

 2005 Pearson Education, Inc. All rights reserved. 31 Outline PassArray.java (2 of 2) Line 30 Lines Lines Program output

 2005 Pearson Education, Inc. All rights reserved. 32 Outline GradeBook.java (1 of 5) Line 7 Line 13

 2005 Pearson Education, Inc. All rights reserved. 33 Outline GradeBook.java (2 of 5)

 2005 Pearson Education, Inc. All rights reserved. 34 Outline GradeBook.java (3 of 5) Lines Lines 75-80

 2005 Pearson Education, Inc. All rights reserved. 35 Outline GradeBook.java (4 of 5) Lines Lines

 2005 Pearson Education, Inc. All rights reserved. 36 Outline GradeBook.java (5 of 5) Lines Loop through grades to display each grade

 2005 Pearson Education, Inc. All rights reserved. 37 Outline GradeBookTest.java (1 of 2) Line 10 Line 13

 2005 Pearson Education, Inc. All rights reserved. 38 Outline GradeBookTest.java (2 of 2) Program output

 2005 Pearson Education, Inc. All rights reserved Multidimensional Arrays Multidimensional arrays – Tables with rows and columns Two-dimensional array m-by-n array

 2005 Pearson Education, Inc. All rights reserved. 40 Fig | Two-dimensional array with three rows and four columns.

 2005 Pearson Education, Inc. All rights reserved Multidimensional Arrays (Cont.) Arrays of one-dimensional array – Declaring two-dimensional array b[2][2] int b[][] = { { 1, 2 }, { 3, 4 } }; – 1 and 2 initialize b[0][0] and b[0][1] – 3 and 4 initialize b[1][0] and b[1][1] int b[][] = { { 1, 2 }, { 3, 4, 5 } }; – row 0 contains elements 1 and 2 – row 1 contains elements 3, 4 and 5

 2005 Pearson Education, Inc. All rights reserved Multidimensional Arrays (Cont.) Two-dimensional arrays with rows of different lengths – Lengths of rows in array are not required to be the same E.g., int b[][] = { { 1, 2 }, { 3, 4, 5 } };

 2005 Pearson Education, Inc. All rights reserved Multidimensional Arrays (Cont.) Creating two-dimensional arrays with array- creation expressions – Can be created dynamically 3 -by- 4 array int b[][]; b = new int[ 3 ][ 4 ]; Rows can have different number of columns int b[][]; b = new int[ 2 ][ ]; // create 2 rows b[ 0 ] = new int[ 5 ]; // create 5 columns for row 0 b[ 1 ] = new int[ 3 ]; // create 3 columns for row 1

 2005 Pearson Education, Inc. All rights reserved. 44 Outline InitArray.java (1 of 2) Line 9 Line 10 Use nested array initializers to initialize array1 Use nested array initializers of different lengths to initialize array2

 2005 Pearson Education, Inc. All rights reserved. 45 Outline InitArray.java (2 of 2) Line 26 Line 27 Program output array[row].length returns number of columns associated with row subscript Use double-bracket notation to access two-dimensional array values

 2005 Pearson Education, Inc. All rights reserved Multidimensional Arrays (Cont.) Common multidimensional-array manipulations performed with for statements – Many common array manipulations use for statements E.g., for ( int column = 0; column < a[ 2 ].length; column++ ) a[ 2 ][ column ] = 0;

 2005 Pearson Education, Inc. All rights reserved Case Study: Class GradeBook Using a Two-Dimensional Array Class GradeBook – One-dimensional array Store student grades on a single exam – Two-dimensional array Store grades for a single student and for the class as a whole

 2005 Pearson Education, Inc. All rights reserved. 48 Outline GradeBook.java (1 of 7) Line 7 Line 10 Declare two-dimensional array grades GradeBook constructor accepts a String and a two-dimensional array

 2005 Pearson Education, Inc. All rights reserved. 49 Outline GradeBook.java (2 of 7)

 2005 Pearson Education, Inc. All rights reserved. 50 Outline GradeBook.java (3 of 7) Lines Loop through rows of grades to find the lowest grade of any student

 2005 Pearson Education, Inc. All rights reserved. 51 Outline GradeBook.java (4 of 7) Lines Lines Loop through rows of grades to find the highest grade of any student Calculate a particular student’s semester average

 2005 Pearson Education, Inc. All rights reserved. 52 Outline GradeBook.java (5 of 7) Lines Calculate the distribution of all student grades

 2005 Pearson Education, Inc. All rights reserved. 53 Outline GradeBook.java (6 of 7)

 2005 Pearson Education, Inc. All rights reserved. 54 Outline GradeBook.java (7 of 7)

 2005 Pearson Education, Inc. All rights reserved. 55 Outline GradeBookTest.java (1 of 2) Lines Declare gradesArray as 3- by-10 array Each row represents a student; each column represents an exam grade

 2005 Pearson Education, Inc. All rights reserved. 56 Outline GradeBookTest.java (2 of 2) Program output

 2005 Pearson Education, Inc. All rights reserved Variable-Length Argument Lists Variable-length argument lists – New feature in J2SE 5.0 – Unspecified number of arguments – Use ellipsis ( … ) in method’s parameter list Can occur only once in parameter list Must be placed at the end of parameter list – Array whose elements are all of the same type

 2005 Pearson Education, Inc. All rights reserved. 58 Outline VarargsTest.java (1 of 2) Line 7 Lines Line 15 Method average receives a variable length sequence of double s Calculate the total of the double s in the array Access numbers.length to obtain the size of the numbers array

 2005 Pearson Education, Inc. All rights reserved. 59 Outline VarargsTest.java (2 of 2) Line 29 Line 31 Line 33 Program output Invoke method average with two arguments Invoke method average with three arguments Invoke method average with four arguments

 2005 Pearson Education, Inc. All rights reserved. 60 Common Programming Error 7.6 Placing an ellipsis in the middle of a method parameter list is a syntax error. An ellipsis may be placed only at the end of the parameter list.

 2005 Pearson Education, Inc. All rights reserved Using Command-Line Arguments Command-line arguments – Pass arguments from the command line String args[] – Appear after the class name in the java command java MyClass a b – Number of arguments passed in from command line args.length – First command-line argument args[ 0 ]

 2005 Pearson Education, Inc. All rights reserved. 62 Outline InitArray.java (1 of 2) Line 6 Line 9 Line 16 Lines Lines Array args stores command- line arguments Check number of arguments passed in from the command line Obtain first command-line argument Obtain second and third command-line arguments Calculate the value for each array element based on command-line arguments

 2005 Pearson Education, Inc. All rights reserved. 63 Outline InitArray.java (2 of 2) Program output Missing command-line arguments Three command-line arguments are 5, 0 and 4 Three command-line arguments are 10, 1 and 2