Arrays Chapter 8.

Slides:



Advertisements
Similar presentations
Starting Out with C++: Early Objects 5/e © 2006 Pearson Education. All Rights Reserved Starting Out with C++: Early Objects 5 th Edition Chapter 8 Arrays.
Advertisements

Chapter 8. 2 Objectives You should be able to describe: One-Dimensional Arrays Array Initialization Arrays as Arguments Two-Dimensional Arrays Common.
Chapter 9: Arrays and Strings
Chapter 9: Arrays and Strings
C++ for Engineers and Scientists Third Edition
Chapter 8 Arrays and Strings
Lesson 7 Arrays CS 1 Lesson 7 -- John Cole1. Arrays Hold Multiple Values Array: variable that can store multiple values of the same type Values are stored.
Chapter 7: Arrays. Outline Array Definition Access Array Array Initialization Array Processing 2D Array.
Chapter 7: Arrays. In this chapter, you will learn about: One-dimensional arrays Array initialization Declaring and processing two-dimensional arrays.
 2006 Pearson Education, Inc. All rights reserved Arrays.
Chapter 8 Arrays and Strings
C++ Programming: From Problem Analysis to Program Design, Fifth Edition Arrays.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 8: Arrays Starting Out with C++ Early Objects Seventh Edition by.
C++ for Engineers and Scientists Second Edition Chapter 11 Arrays.
Copyright © 2014, 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley C-Strings, Arrays, and String Class Review.
Lecture: Arrays. 7.1 Arrays Hold Multiple Values.
1 Arrays and Vectors Chapter 7 Arrays and Vectors Chapter 7.
Section 5 - Arrays. Problem solving often requires information be viewed as a “list” List may be one-dimensional or multidimensional List is implemented.
1 Chapter 7 Arrays. 2 Topics 7.1 Arrays Hold Multiple Values 7.2 Accessing Array Elements 7.3 No Bounds Checking in C Array Initialization 7.5 Processing.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 8: Arrays Starting Out with C++ Early Objects Seventh Edition by.
+ Chapter 8: Arrays Starting Out with C++ Early Objects Seventh Edition by Tony Gaddis, Judy Walters, and Godfrey Muganda.
A First Book of C++: From Here To There, Third Edition2 Objectives You should be able to describe: One-Dimensional Arrays Array Initialization Arrays.
Copyright 2004 Scott/Jones Publishing Alternate Version of STARTING OUT WITH C++ 4 th Edition Chapter 8 Arrays.
Chapter 7: Arrays. Outline Array Definition Access Array Array Initialization Array Processing 2D Array.
Chapter 8: Arrays Starting Out with C++ Early Objects Seventh Edition by Tony Gaddis, Judy Walters, and Godfrey Muganda.
 2008 Pearson Education, Inc. All rights reserved. 1 Arrays and Vectors.
Copyright 2003 Scott/Jones Publishing Standard Version of Starting Out with C++, 4th Edition Chapter 7 Arrays.
1 Chapter 12 Arrays. 2 C++ Data Types structured array struct union class address pointer reference simple integral enum char short int long bool floating.
Copyright © 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Starting Out with C++ Early Objects Sixth Edition Chapter 8: Arrays by Tony.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 8: Arrays Starting Out with C++ Early Objects Seventh Edition by.
Copyright 2003 Scott/Jones Publishing Alternate Version of Starting Out with C++, Third Edition Chapter 8 Arrays.
Arrays Chapter 12. Overview Arrays and their properties Creating arrays Accessing array elements Modifying array elements Loops and arrays.
Chapter 7 Arrays Csc 125 Introduction to C++. Topics Arrays Hold Multiple Values Array Operations Arrays as function arguments Two-dimensional arrays.
Copyright © 2015, 2012, 2009 Pearson Education, Inc., Publishing as Addison-Wesley All rights reserved. Chapter 7: Arrays.
Arrays Chapter 7. Arrays Hold Multiple Values Array: variable that can store multiple values of the same type Values are stored in adjacent memory locations.
C++ Programming Lecture 14 Arrays – Part I The Hashemite University Computer Engineering Department (Adapted from the textbook slides)
CPS120 Introduction to Computer Science Exam Review Lecture 18.
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.
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 7- 1.
Lecture 8 – Array (Part 1) FTMK, UTeM – Sem /2014.
Copyright © 2012 Pearson Education, Inc. Chapter 7: Arrays.
VISUAL C++ PROGRAMMING: CONCEPTS AND PROJECTS Chapter 7A Arrays (Concepts)
ARRAYS (C) KHAERONI, M.SI. OVERVIEW Introduction to Arrays Arrays in Functions Programming with Arrays Multidimensional Arrays.
 2006 Pearson Education, Inc. All rights reserved Arrays and Vectors.
Chapter 7: Arrays. 7.1 Arrays Hold Multiple Values.
Copyright © 2010 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Arrays Hold Multiple Values 7.1.
Lecture 2 Arrays. Topics 1 Arrays hold Multiple Values 2 Accessing Array Elements 3 Inputting and Displaying Array Contents 4 Array Initialization 5 Using.
Chapter 8: Arrays. Arrays Hold Multiple Values Array: variable that can store multiple values of the same type Values are stored in adjacent memory locations.
Objectives You should be able to describe: One-Dimensional Arrays
A FIRST BOOK OF C++ CHAPTER 7 ARRAYS. OBJECTIVES In this chapter, you will learn about: One-Dimensional Arrays Array Initialization Arrays as Arguments.
Alternate Version of Starting Out with C++, Third Edition
Chapter 7: Arrays.
Lecture 6 Arrays and Vectors
Chapter 7: Arrays.
Arrays An array is a grouping of elements of the same type that share a common base name Can have any number of elements in the array Individual elements.
Chapter 8: Arrays Starting Out with C++ Early Objects Ninth Edition
Computer Programming BCT 1113
Lecture 3 C & C++ programming.
Vectors Holds a set of elements, like an array
New Structure Recall “average.cpp” program
Chapter 7: Arrays.
7 Chapter Arrays.
Chapter 8: Arrays Starting Out with C++ Early Objects Eighth Edition
7 Arrays.
Standard Version of Starting Out with C++, 4th Edition
7 Arrays.
Arrays An array is a grouping of elements of the same type that share a common base name Can have any number of elements in the array Individual elements.
Chapter 8: Arrays Starting Out with C++ Early Objects Ninth Edition
Presentation transcript:

Arrays Chapter 8

Arrays Hold Multiple Values Array: variable that can store multiple values of the same type Values are stored in adjacent memory locations Declared using [] operator int tests[5];

Array Storage in Memory The definition int tests[5]; allocates the following memory first element second element third element fourth element fifth element

Array Terminology In the definition int tests[5]; int is the data type of the array elements tests is the name of the array 5, in [5], is the size declarator. It shows the number of elements in the array. The size of an array is the number of bytes allocated for it (number of elements) * (bytes needed for each element)

Array Terminology Examples Assumes int uses 4 bytes and double uses 8 bytes int tests[5]; // holds 5 ints; // size is 20 bytes double volumes[10]; // holds 10 doubles // size is 80 bytes

Accessing Array Elements Each array element has a subscript, used to access the element. Subscripts start at 0 subscripts 1 2 3 4 5

Accessing Array Elements Array elements (accessed by array name and subscript) can be used as regular variables tests[0] = 79; cout << tests[0]; cin >> tests[1]; tests[4] = tests[0] + tests[1]; cout << tests; // illegal due to // missing subscript 1 2 3 4 5 tests

Array Subscripts Array subscript can be an integer constant, integer variable, or integer expression Examples: Subscript is cin >> tests[3]; int constant cout << tests[i]; int variable cout << tests[i+j]; int expression

Global vs. Local Arrays Global arrays initialize all elements Numeric elements are initialized to 0 Strings and characters are initialized to NULL Local arrays leave all elements uninitialized by default It is the programmer’s job to make sure they are initialized before they are used

Inputting and Displaying Array Contents To access a single element of an array, use a subscript (as previously shown) int tests[5]; // Define 5-element array cout << “Enter first test score ”; cin >> tests[0]; Related, sample programs from the text are noted. See pr8-01.cpp

Inputting and Displaying All Array Elements To access each element of an array Use a loop Let the loop control variable be the array subscript A different array element will be referenced each time through the loop for (i = 0; i < 5; i++) cout << tests[i] << endl; See pr8-02.cpp

Getting Array Data from a File int sales[5]; ifstream datafile; datafile.open("sales.dat"); if (!datafile) cout << "Error opening data file\n"; else { // Input daily sales for (int day = 0; day < 5; day++) datafile >> sales[day]; datafile.close(); } See pr8-03.cpp

No Bounds Checking There are no checks in C++ that an array subscript is in range An invalid array subscript can cause program to overwrite other memory Example: int i = 4; int num[3]; num[i] = 25; num [0] [1] [2] 25 See pr8-04.cpp

Array Initialization Can be initialized during program execution with assignment statements tests[0] = 79; tests[1] = 82; // etc. Can be initialized at array definition with an initialization list int tests[5] = {79,82,91,77,84}; See pr8-05.cpp, pr8-06.cpp, and pr8-07.cpp

Partial Array Initialization If array is initialized at definition with fewer values than the size declarator of the array, remaining elements will be set to 0 or NULL int tests[5] = {79, 82}; Initial values used in order; cannot skip over elements to initialize noncontiguous range 79 82 See pr8-08.cpp

Implicit Array Sizing Can determine array size by the size of the initialization list short quizzes[]={12,17,15,11}; Must use either array size declarator or initialization list when array is defined 12 17 15 11

Processing Array Contents Array elements can be treated as ordinary variables of the same type as the array used in arithmetic operations, in relational expressions, etc. Example: if (principalAmt[3] >= 10000) interest = principalAmt[3] * intRate1; else interest = principalAmt[3] * intRate2; See pr8-09.cpp

Using Increment and Decrement Operators with Array Elements When using ++ and -- operators, don’t confuse the element with the subscript tests[i]++; // adds 1 to tests[i] tests[i++]; // increments i; but has // no effect on tests

Sum of Array Elements Use a simple loop to add together array elements float average, sum = 0; for (int tnum = 0; tnum < 5; tnum++) sum += tests[tnum]; Once summed, average can be computed average = sum/5;

Largest Array Element Use a loop to examine each element and find the largest element (i.e., one with the largest value) int largest = tests[0]; for (int tnum = 1; tnum < 5; tnum++) { if (tests[tnum] > largest) largest = tests[tnum]; } cout << “Highest score is ” << largest; A similar algorithm exists to find the smallest element See pr8-10.cpp and pr8-11.cpp

C-Strings and string Objects Can be processed using array name Entire string at once or One element at a time (by using a subscript) string city; cout << "Enter city name: "; cin >> city; See pr8-12.cpp 'S' 'a' 'l' 'e' 'm' city[0] city[1] city[2] city[3] city[4]

Using Parallel Arrays Parallel arrays: two or more arrays that contain related data Subscript is used to relate arrays elements at same subscript are related The arrays do not have to hold data of the same type

Parallel Array Example int size = 5; string name[size]; // student name float average[size]; // course average char grade[size]; // course grade 1 2 3 4 name average grade

Parallel Array Processing int size = 5; string name[size]; // student name float average[size]; // course average char grade[size]; // course grade ... for (int i = 0; i < size; i++) cout << " Student: " << name[i] << " Average: " << average[i] << " Grade: " << grade[i] << endl; See pr8-13.cpp

The typedef Statement Creates an alias for a simple or structured data type Format: typedef existingType newName; Example: typedef unsigned int Uint; Uint tests[5]; // array of // unsigned ints

Uses of typedef Used to make code more readable Can be used to create alias for array of a particular type // Define yearArray as a data type // that is an array of 12 ints typedef int yearArray[12]; // Create two of these arrays yearArray highTemps, lowTemps;

Arrays as Function Arguments To define a function that has an array parameter, use empty [] for array argument To pass an array to a function, just use the array name // Function prototype void showScores(int []); // Function header void showScores(int tests[]) // Function call showScores(tests);

Passing an Array Element Passing a single array element to a function is no different than passing a regular variable of that data type Function does not need to know the value it receives is coming from an array displayValue(score[i]); // call void displayValue(int item) // header { cout << item << endl; } See pr8-14.cpp

Passing an Entire Array Just use array name, without any brackets, as the argument Also pass array size so the function knows how many elements to process showScores(tests, 5); // call void showScores(int[], int); // prototype void showScores(int A[], int size) // header See pr8-15.cpp and pr8-18.cpp

Using typedef with a Passed Array Can use typedef to simplify function prototype and heading // Make intArray an integer array // of unspecified size typedef int intArray[]; // Function prototype void showScores(intArray, int); // Function header void showScores(intArray tests, int size) See pr8-16.cpp

Modifying Arrays in Functions Array parameters in functions are similar to reference variables Changes made to array in a function are made to the actual array in the calling function Must be careful that an array is not inadvertently changed by a function See pr8-17.cpp

Two-Dimensional Arrays Can define one array for multiple sets of data Like a table in a spreadsheet Use two size declarators in definition int exams[4][3]; Number of rows Number of cols

Two-Dimensional Array Representation int exams[4][3]; Use two subscripts to access element exams[2][2] = 86; columns exams[0][0] exams[0][1] exams[0][2] exams[1][0] exams[1][1] exams[1][2] exams[2][0] exams[2][1] exams[2][2] exams[3][0] exams[3][1] exams[3][2] r o w s See pr8-19.cpp

Initialization at Definition Two-dimensional arrays are initialized row-by-row int exams[2][2] = { {84, 78}, {92, 97} }; Can omit inner { } 84 78 92 97

Passing a Two-Dimensional Array to a Function Use array name as argument in function call getExams(exams, 2); Use empty [] for row and a size declarator for col in the prototype and header // Prototype void getExams(int[][2], int); // Header void getExams(int exams[][2], int rows) See pr8-20.cpp

Using typedef with a Two-Dimensional Array Can use typedef for simpler notation typedef int intExams[][2]; ... // Function prototype void getExams(intExams, int); // Function header void getExams(intExams exams, int rows)

Arrays with Three or More Dimensions Can define arrays with any number of dimensions short rectSolid[2][3][5]; float timeGrid[3][4][3][4]; When used as parameter, specify size of all but 1st dimension void getRectSolid(short [][3][5]); See pr8-21.cpp

Vectors Defined in the Standard Template Library (STL) Covered in a later chapter Must include vector header file to use vectors #include <vector> Holds a set of elements, like an array But can grow and shrink in number of elements No need to specify size when defined Automatically adds space as more is needed

Vectors Can hold values of any type Can use [] to access elements Type is specified when a vector is defined vector<int> scores; vector<float> volumes; Can use [] to access elements

Defining Vectors Define a vector of integers (starts with 0 elements) vector<int> scores; Define int vector with initial size 30 elements vector<int> scores(30); Define 20-element int vector and initialize all elements to 0 vector<int> scores(20, 0); Define int vector initialized to size and contents of another vector vector<int> scores(finals); See pr8-22.cpp

Growing a Vector’s Size Use push_back member function to add an element to a full array or to an array that had no defined size // Add a new element holding a 75 scores.push_back(75); Use size member function to determine number of elements currently in a vector howbig = scores.size(); See pr8-23.cpp and pr8-24.cpp

Removing Vector Elements Use pop_back member function to remove last element from vector scores.pop_back(); To remove all contents of vector, use clear member function scores.clear(); To determine if vector is empty, use empty member function while (!scores.empty()) ... See pr8-25.cpp, pr8-26.cpp, and pr8-27.cpp

Arrays of Structures Structures can be used as array elements { struct Student { int studentID; string name; short year; float gpa; }; Student class[30]; // Holds 30 Student // structures

Arrays of Structures Use array subscript to access a specific structure in the array Then use dot operator to access members of that structure cin >> class[25].studentID; cout << class[i].name << " has GPA " << s[i].gpa << endl; See pr8-29.cpp

Arrays of Class Objects Class objects can also be used as array elements class Square { private: int side; public: Square(int s = 1) { side = s; } int getSide() { return side; } }; Square shapes[10]; // Create array of 10 // Square objects

Arrays of Class Objects Use subscript to access a specific object in the array Then use dot operator to access members of that object for (i = 0; i < 10; i++) cout << shapes[i].getSide() << endl; See pr8-30.cpp

Initializing Arrays of Objects Can use default constructor to perform same initialization for all objects Can use initialization list to supply specific initial values for each object Square shapes[5] = {1,2,3,4,5}; Default constructor is used for the remaining objects if initialization list is too short Square boxes[5] = {1,2,3}; See pr8-31.cpp and pr8-32.cpp

Initializing Arrays of Objects If an object is initialized with a constructor that takes > 1 argument, the initialization list must include a call to the constructor for that object Rectangle spaces[3] = { Rectangle(2,5), Rectangle(1,3), Rectangle(7,7) }; See pr8-33.cpp