Array. Convert Numbers in Different Base Systems Generate values to a series of numbers in different base systems: Base is between 2 and 9; Maximum number.

Slides:



Advertisements
Similar presentations
1 1-d Arrays. 2 Array Many applications require multiple data items that have common characteristics  In mathematics, we often express such groups of.
Advertisements

Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 7- 1 Overview 7.1 Introduction to Arrays 7.2 Arrays in Functions 7.3.
Dale/Weems/Headington
Computer Science 1620 Loops.
Arrays Hanly - Chapter 7 Friedman-Koffman - Chapter 9.
1 Lecture 20:Arrays and Strings Introduction to Computer Science Spring 2006.
Chapter 9: Arrays and Strings
Computer Science 1620 Arrays. Problem: Given a list of 5 student grades, adjust the grades so that the average is 70%. Program design: 1. read in the.
Chapter 5 - Arrays CSC 200 Matt Kayala 2/27/06. Learning Objectives  Introduction to Arrays  Declaring and referencing arrays  For-loops and arrays.
Chapter 9: Arrays and Strings
1 Pointers, Dynamic Data, and Reference Types Review on Pointers Reference Variables Dynamic Memory Allocation –The new operator –The delete operator –Dynamic.
Chapter 8 Arrays and Strings
Arrays. Objectives Learn about arrays Explore how to declare and manipulate data into arrays Learn about “array index out of bounds” Become familiar with.
Chapter 7: Arrays. Outline Array Definition Access Array Array Initialization Array Processing 2D Array.
CMSC 104, Version 8/061L22Arrays1.ppt Arrays, Part 1 of 2 Topics Definition of a Data Structure Definition of an Array Array Declaration, Initialization,
Elements of a C++ program 1. Review Algorithms describe how to solve a problem Structured English (pseudo-code) Programs form that can be translated into.
1 Chapter 9 Scope, Lifetime, and More on Functions.
Arrays One-Dimensional initialize & display Arrays as Arguments Part I.
C++ Arrays. Agenda What is an array? What is an array? Declaring C++ arrays Declaring C++ arrays Initializing one-dimensional arrays Initializing one-dimensional.
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.
Chapter 8 Arrays and Strings
1 Chapter 8 Scope, Lifetime, and More on Functions Dale/Weems/Headington.
C++ Tutorial Hany Samuel and Douglas Wilhelm Harder Department of Electrical and Computer Engineering University of Waterloo Copyright © 2006 by Douglas.
C++ Programming: From Problem Analysis to Program Design, Fifth Edition Arrays.
Pointers OVERVIEW.
CS Midterm Study Guide Fall General topics Definitions and rules Technical names of things Syntax of C++ constructs Meaning of C++ constructs.
CHAPTER 7 arrays I NTRODUCTION T O C OMPUTER P ROGRAMMING (CSC425)
Organizing Heterogeneous Data Arrays allow a programmer to organize lists of values that are all of the same type (homogeneous). But we are often faced.
 2003 Prentice Hall, Inc. All rights reserved. 1 Arrays Outline Introduction Arrays Declaring Arrays Examples Using Arrays.
Review Binary Numbers Bit : 0 or 1 Byte: 8 bites 256 different values 2 8 KB : 1024 bytes 2 10 bytes MB : 1024 * 1024 bytes 2 10 * 2 10 (2 20 ) bytes GB.
Arrays in C++: Numeric Character (Part 2). Passing Arrays as Arguments in C++, arrays are always passed by reference (Pointer) whenever an array is passed.
Control Structures RepetitionorIterationorLooping Part I.
Slide 1 Chapter 5 Arrays. Slide 2 Learning Objectives  Introduction to Arrays  Declaring and referencing arrays  For-loops and arrays  Arrays in memory.
Chapter 5 Arrays. Copyright © 2006 Pearson Addison-Wesley. All rights reserved. 5-2 Learning Objectives  Introduction to Arrays  Declaring and referencing.
CHAPTER 10 ARRAYS AND FUNCTIONS Prepared by: Lec. Ghader Kurdi.
1 One Dimensional Arrays Chapter 11 2 "All students to receive arrays!" reports Dr. Austin. Declaring arrays scores :
Copyright © 2002 W. A. Tucker1 Chapter 9 Lecture Notes Bill Tucker Austin Community College COSC 1315.
Liang, Introduction to Programming with C++, Second Edition, (c) 2010 Pearson Education, Inc. All rights reserved Chapter 6 Arrays.
Chapter 7 Arrays. Introductions Declare 1 variable to store a test score of 1 student. int score; Declare 2 variables to store a test score of 2 students.
 2008 Pearson Education, Inc. All rights reserved. 1 Arrays and Vectors.
Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 1 Chapter Array Basics.
Copyright © 2000, Department of Systems and Computer Engineering, Carleton University 1 Introduction An array is a collection of identical boxes.
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.
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.
Variables and memory addresses
Data Types Storage Size Domain of all possible values Operations 1.
Functions Structured Programming. Topics to be covered Introduction to Functions Defining a function Calling a function Arguments, local variables and.
1 Programming in C++ Dale/Weems/Headington Chapter 9 Additional Control Structures (Switch, Do..While, For statements)
1 Chapter 9 Scope, Lifetime, and More on Functions.
Arrays Chapter 12. Overview Arrays and their properties Creating arrays Accessing array elements Modifying array elements Loops and arrays.
Class Method Read class Student { private: string id; string firstName, lastName; float gpa; public: // Will the method change any data members? // Yes!
1 Parameter passing Call by value The caller evaluates the actual parameters and passes copies of their values to the called function. Changes to the copies.
CS 1430: Programming in C++ 1. Test 2 Friday Functions Arrays For Loops Understand Concepts and Rules Memorize Concepts and Rules Apply Concepts and Rules.
CPS120 Introduction to Computer Science Exam Review Lecture 18.
1 Lecture 4: Part1 Arrays Introduction Arrays  Structures of related data items  Static entity (same size throughout program)
CS Class 04 Topics  Selection statement – IF  Expressions  More practice writing simple C++ programs Announcements  Read pages for next.
CS 1430: Programming in C++.
CHAPTER 6 ARRAYS IN C 1 st semester King Saud University College of Applied studies and Community Service Csc 1101 F. Alakeel.
Array. Array is a group of data of the same type. Array elements have a common name –The array as a whole is referenced through the common name Individual.
Chapter 5 Arrays Copyright © 2016 Pearson, Inc. All rights reserved.
1 C++ Data Types structured array struct union class address pointer reference simple integral enum char short int long bool floating float double long.
1 Programming in C++ Dale/Weems/Headington Chapter 11 One-Dimensional Arrays.
Write code to prompt for 5 grades, read them in, print “Thank you”, then reprint the 5 grades and their average. cout >
New Structure Recall “average.cpp” program
C++ Data Types Simple Structured Address Integral Floating
CS 1430: Programming in C++.
Chapter 9 Scope, Lifetime, and More on Functions
CS1430: Programming in C++ Section 2 Instructor: Qi Yang 213 Ullrich
CS 1430: Programming in C++.
CS 1430: Programming in C++.
Presentation transcript:

Array

Convert Numbers in Different Base Systems Generate values to a series of numbers in different base systems: Base is between 2 and 9; Maximum number of digits is 100. Number is NOT in reverse order! Example: Value = 1* * *3 + 1 = 46 How do we know how many digits a number have? Use Array!

Convert Numbers in Different Base Systems const int MAX_DIGIT = 100; const char ZERO = '0‘; int base, counter, size = 0, numValue = 0; char chDigit; int number[MAX_DIGIT]; cin >> base >> chDigit; while ( chDigit != '\n' ) { number[size] = chDigit - ZERO; size ++; cin.get(chDigit); } cout << endl << "Given base " << base << ", the decimal value of "; for ( counter = 0; counter < size; counter ++ ) { numValue += number[counter] * pow ( base, size - counter - 1 ); cout << number[counter]; } cout << " is " << numValue << "."; return 0; // declare an array // for loop

C++ Data Types structured array struct union class address pointer reference simple integral enum char short int long bool floating float double long double

One-Dimensional Array A one-dimensional array is a structured collection of components (array elements) that can be accessed individually by specifying the position of a component with a single index value. An array is a homogeneous data structure: All components are of the same data type A component of an array is accessed by its position in the structure.

Highest, Lowest and Average of 100 Scores float score; float total, max, min, avg; int scoreCount; // Using one variable to input and process scores // One score at a time // When do we need to keep all scores? // Is my score below or above the average? // How do we keep all scores? // Array!

Declaration of Variables int scoreCount; float score, total; char grade; string courseName; bool validInput; // Memory Allocation // Address for each variable // Size for each data type // int : 2 bytes // float : 4 bytes // char : 1 byte // string: # of chars plus one 7

Declaration of Arrays Syntax: Example: float scores[100];// 100 floats char chs[20];// 20 chars int nums[30]; // 30 integers string allNames[100];// 100 strings bool prog3Completed[26];// 26 bool values DataType ArrayName [ConstantExpression];

Memory Allocation for Array nums int nums[30]; // 30 integers // Address: the first element’s address // How many bytes? // 30 * 2: 60 bytes 9 The base address of an array is its beginning address in memory Address:

Array Size Must Be Constant Expressions const int MAX_SIZE = 30; int size = 30; int nums[30]; float ArrayA[MAX_SIZE]; // Valid? // Yes! // number of bytes? float ArrayB[size]; // Valid? // NO! float ArrayC[MAX_SIZE * 10]; // Valid? // Yes! // number of bytes? 10 However, no magic number in your programs!

Array Element Array Indices int nums[30]; Array Element nums[0]nums[1] nums[29] 11 Array Element and Array Index

How to access array elements? Use array index to specify array element. int value = num[3]; cout << value; // we get 50! Index of any array begins with 0 ! Never go out of the array boundary! Exercise: int m = 2; what is num[m+1]? what is num[m]+1?

An array element is the same as a single variable. Operations on array elements: Input Output Arithmetic operations Assignment Comparison Function parameters … 13 Operations on Array Elements

Example: Operations on Array Elements int nums[30]; // Read an integer and store it in the 1 st element of nums. cin >> nums[0]; // Incement the 1 st element of nums by one. nums[0] ++; // Assign the value of the 1 st element of nums to // the 2 nd element of nums. nums[1] = nums[0]; // Incement the 2nd element of nums by the value of size. nums[1] += size; // Set the last element of nums to the value of size. nums[29] = size; // Assign the value of the 16 th element of nums to size. size = nums[15];

Example: Operations on Array Elements int nums[30]; // Display 1 st element of nums with a width of 9. cout << endl << setw(9) << nums[0]; // Compute the average of the 1 st and last elements of // nums and store it in avg. avg = (nums[0] + nums[29]) / 2.0; // If the 2 nd element is not zero, display the float // quotient of 1 st element divided by 2 nd. if (nums[1] != 0) cout << "Quotient = " << float(nums[0]) / nums[1]; // Call function Largest to find the max value between // the first three elments of nums and store it in Max. // Function prototype: // int Largest(int num1, int num2, int num3); Max = Largest(nums[0], nums[1], nums[2]);

Exercise const int MAX_SIZE = 30; int nums[MAX_SIZE], index; cin >> nums[29]; // Valid. cin >> nums[30]; // Not Valid! Out of Boundary Error! cout << nums[MAX_SIZE - 1]; // Valid. cout << nums[MAX_SIZE]; // Not Valid! Out of Boundary Error! cin >> index; if (index = 0) nums[index] = nums[10]; // Valid.

Assign Values to An Array Initializing arrays in declarations. int age[5] = {23, 19, 33, 45, 60}; float temperature[] = {0.0, , -12, 98.6}; in C++, you are allowed to omit the size of an array when initializing it! The compiler figures out the size by itself! Use loop to assign values to an array. int age[5]; int index = 0; while ( index < 5 ) { cin >> age[index]; index ++; } for loop is a better way to handle arrays! int i; for (i = 0; i < 5; i ++ ) cin >> age[i];

For Loop Syntax: Initialization is an assignment statement; Condition is a logic expression; Update is an incrementing or decrementing statement. Compare with while loop: for ( Initialization; Condition; Update ) { loop body; } Initialization; while ( condition ) { loop body; update; }

Translate between while and for loops Calculate the sum of 1 to 10: int total = 0; int num = 1; while ( num <= 10 ) { total += num; num ++; } int total = 0; int num; for ( num = 1; num <= 10; num ++ ) { total += num; }

Use for loop to handle arrays You MUST use for loop to handle arrays if possible! You can use i, j, k as the LCV in for loops without violating the variable naming rule. int ArrayA[30], size, j; cin >> size; // Assume size is between 1 and 30 // Input to an array for (int i = 0; i < size; i ++) cin >> ArrayA[i]; // Output array for (j = 0; j < size; j ++) cout << endl << setw(8) << ArrayA[j];

Highest, Lowest and Average of 100 Scores float score[NUM_SCORE]; float total = 0, max = 0, min = 0, avg, index; for (int i = 0; i < NUM_SCORE; i++) { cin >> score[i]; if ( max < score[i] || i == 0) max = score[i]; if ( min > score[i] || i == 0) min = score[i]; total += score[i]; } avg = total / NUM_SCORE; cout << “\nThe average score of the “ << NUM_SCORE << “ scores is “ << avg << endl; cout << “Please enter your score ID: “; cin >> index; cout << endl << “You score is ” << score[index] << “.“; // what is the scope of i? // within the for loop! // because it is declared // in the for statement.

Passing arrays as function parameters Basic Data Types (char, int, float, string, bool) Pass by Value (without &) Pass by Reference (with &) Arrays (of any data type) Always Pass by Reference (Never &) The base address of the array is sent to the function! Why? Save Space and Time for copying values

Using a function to read data to an array The size (number of elements) is known Function Prototype Function Name InputToArray Function Type void //How to return an array? Parameters s[] : array of float In, Out, InOut OUT size: int, number of elements of s[] In, Out, InOut IN // Parameters: (Out, In) void InputToArray(float s[], int size); // No &!

Using a function to read data to an array // // The function reads size float values into // array s[], assuming size is positive // and in the range. // Parameters: (out, in) // void InputToArray(float s[], int size) { for (int i = 0; i < size; i++) cin >> s[i]; } // What’s the value of size?

Using a function to read data to an array const int MAX_SIZE = 100; void InputToArray(float s[], int size); int main() { int count; float scores[MAX_SIZE], average; cout << "Please enter the size of the array: "; cin >> count; // Call function to input data to array Scores[] InputToArray(scores, count); // No [] for array as actual parameter // No type for any actual parameters return 0; }

Passing arrays as IN parameters Basic Data Types (char, int, float, string, bool) Pass by Value (without &) In Parameters Pass by Reference (with &) Out and InOut Parameters Arrays (of any data type) Always Pass by Reference (Never &) In Parameters: const const is used to prevent the function from modifying the caller’s array value.

Using a function to compute average The size (number of elements) is known Function Prototype Function name ArrayAvg Function type float Parameters s[] : array of float In size: int, number of elements of s[] In // Parameters: (In, In) float ArrayAvg(const float s[], int size); // Array is always passed by reference // Use const for In array parameter // No const for size

Using a function to compute average // // The function computes and returns the average of all // array elements of s[], assuming size is positive // and in the range. // Parameters: (In, In) // float ArrayAvg ( const float s[], int size ) { float total; total = 0; for (int i = 0; i < size; i++) total += s[i]; return total / size; } // Compute average after the for loop. // Not inside the loop!

Using a function to compute average const int MAX_SIZE = 100; void InputToArray(float s[], int size); float ArrayAvg(const float s[], int size); int main() { int count; float Scores[MAX_SIZE], average; cout << "Please input the size of the array: "; cin >> count; InputToArray(Scores, count); // Function call: No type! No []! average = ArrayAvg(Scores, count); // Function call: No type! No []! cout << “The average score: “ << average; return 0; }

Passing arrays as function parameters IN parameter: float ArrayAvg(const float s[], int size); must use const no &! OUT and INOUT parameters: void InputArray(float s[], int size); no &! Function call: InputToArray(Scores, count); average = ArrayAvg(Scores, count); no [ ], & or data type!

Read value and size of an array // // The function reads float values into array s[] and // count the actual size of s[]. User stops inputting // by entering -1. Once the user input maxSize elements, // the function will stop reading the input. // Parameters: (out, out, in) // void InputSizeAndValues(float s[], int& size, int maxSize) { size = 0; cin >> s[size]; while ( s[size] != -1 && size < maxSize ) { size ++; cin >> s[size]; } return; } // What’s the value of size? if we have constant MAX_SIZE, do we still need this parameter?

Linear Search Is a value in the array? Where is the Maximum/Minimum element in the array?

Find a target in an array void InputToArray(float s[], int& size); int main() { int count; float MyArray[50], target; InputToArray(MyArray, count); // Assume count is 8 // Is 51 in the array? // Is 60 in the array? cin >> target; // Linear search! return 0; } ???.... ????

Linear Search Function: Find Target in an Array The function returns true if target is found in the array, false otherwise. Function Prototype Function Name SearchArray FindTarget or Find Function Type bool (true/false) Function parameters floatArray[]: array of type float size : int, number of elements of floatArray target : a float number //In, Out, InOut? // Parameters: In, In, In bool SearchArray(const float floatArray[], int size, float target); 34

// // The function has three parameters: // floatArray[]: array of type float // size : int, number of elements of floatArray // target : a float number // The function returns true if target is found in floatArray, // false otherwise. // Parameters: (in, in, in) // bool SearchArray(const float floatArray[], int size, float target) { for (int i = 0; i < size; i++) { if (floatArray[i] == target) return true; else // ? } // When to return false? return false; } ???.... ????

// // The function has three parameters: // floatArray[]: array of type float // size : int, number of elements of // floatArray // target : a float number // The function returns a bool value: // true if target is found in floatArray, // false otherwise. // Parameters: (in, in, in) // bool SearchArray(const float floatArray[], int size, float target) { for (int i = 0; i < size; i++) { if (floatArray[i] == target) return true; } return false; }

const int MAX_SIZE = 50; void InputSizeAndValues ( float s[], int& size, int maxSize ); bool SearchArray ( const float floatArray[], int size, float target ); int main() { float MyArray[MAX_SIZE], target; int count; InputSizeAndValues(MyArray, count, MAX_SIZE); cin >> target; while (!cin.eof()) { if ( SearchArray( MyArray, count, target ) ) cout << "Value " << target << " is in the array."; else cout << "Value " << target << " is NOT in the array."; cin >> target; } return 0; }

Where is the target in the array? // // The function has three parameters: // floatArray[]: array of type float // size : int, number of elements of // floatArray // target : a float number // The function returns the index of the target // if target is found in floatArray, -1 otherwise. // Parameters: (in, in, in) // int SearchArray( const float floatArray[], int size, float target) { for (int i = 0; i < size; i++) { if (floatArray[i] == target) return i; } return -1; }

Linear Search Is a value in the array? Check array elements one at a time until target is found or all array elements have been checked What is the Maximum/Minimum element in the array? Assign the first element to max; Compare max with every array element and update max until all array elements have been compared with

Find the Largest Value of All Array Elements Function Prototype Function Name MaxArrayValue Function Type int (float) Same as the array type Function parameters s[] : array of int size : int, number of elements in s[] //In, Out, InOut? // Parameters: (in, in) int MaxArrayValue(const int s[], int size); 40

// // The function has two parameters: // s[]: array of float // size : int, number of elements in s[] // The function finds and returns the largest array element // of s[], assuming size is positive and in the range. // Parameters: (in, in) // float MaxArrayValue(const float s[], int size) { int max; max = s[0]; for (int i = 1; i < size; i ++) if (s[i] > max) max = s[i]; return max; } 41

// // The function has two parameters: // s[]: array of float // size : int, number of elements in s[] // The function finds and returns the largest array element // of s[], assuming size is positive and in the range. // Parameters: (in, in) // float MaxArrayValue(const float s[], int size) { int max; max = s[0]; for (int i = 0; i < size; i ++) if (s[i] > max) max = s[i]; return max; } //Correct? //Good? 42 Yes. No. Extra comparison: s[0] v.s. s[0]

// // The function has two parameters: // s[]: array of int // size : int, number of elements in s[] // The function finds and returns the largest array element // of s[], assuming size is positive and in the range. // Parameters: (in, in) // float MaxArrayValue(const float s[], int size) { int max; max = 0; for (int i = 0; i < size; i ++) if (s[i] > max) max = s[i]; return max; } //Correct? //No! What if all elements are negative? 43

Parallel Arrays Different arrays sharing the same index. Student records: Student ID First name Last name Gender major GPA

Student Records Const int MAX_STUDENTS = 100; long id [MAX_STUDENTS]; string firstName[MAX_STUDENTS]; string lastName [MAX_STUDENTS]; char gender [MAX_STUDENTS]; string major [MAX_STUDENTS]; float gpa [MAX_STUDENTS]; // Given the student ID, how to output one student’s complete record?

Search and Output a Student Record Algorithm: Read student records into arrays from an input file Read a student ID Search for the ID, if it exists: Find the rest of the student record and print them out Otherwise, tell the user this record does not exist. 1. When reading parallel arrays, keep their index the same! 2. Linear search: return the index of the target student ID! 3. Use the returned index to find the rest parts of a record, because they share the same index!

Read Student Records From a File Function Prototype Function Name ReadRecord Function Type int Function parameters maxSize : int, maximum number of student records to handle id : long array of student ID firstName: string array of first names lastName: string array of last names gender: character array of student genders major: string array of student majors gpa: float array of student gpa //In, Out, InOut? // Parameters: (in, out, out, out, out, out, out ) int ReadRecord ( int maxSize, long id[], string firstName[], string lastName[], char gender[], string major[], float gpa[] );

Read Records From Input File // // The function reads student records from an input file into // different arrays and count the actual number of input records. // Once the user input maxSize elements, the function will stop // reading the input. It returns the actual number of records. // Parameters: (in, out, out, out, out, out, out) // int ReadRecord ( int maxSize, long id[], string firstName[], string lastName[], char gender[], string major[], float gpa[] ) { ifstream inData; inData.open ( "student-record.in" ); int size = 0; inData >> id[size] >> firstName[size] >> lastName[size] >> gender[size] >> major[size] >> gpa[size]; while ( !inData.eof() && size < maxSize ) { size ++; inData >> id[size] >> firstName[size] >> lastName[size] >> gender[size] >> major[size] >> gpa[size]; } inData.close(); return size; } // We will talk about file stream later. // Keep index the same!

Search for ID // // The function has three parameters: // myArray[] : array of type long // size : int, number of elements of // myArray // target : a long number // The function returns the index of the target // in the array if it is found; -1 otherwise. // Parameters: (in, in, in) // int SearchID ( const long myArray[], int size, long target ) { for ( int i = 0; i < size; i++ ) { if ( myArray[i] == target ) return i; } return -1; } // The returned index is used to // locate other parts of a record!

Output a Student Record Function Prototype Function Name OutputRecord Function Type void Function parameters stuID: long, student ID size : int, total number of student records id : long array of student ID firstName: string array of first names lastName: string array of last names gender: character array of student genders major: string array of student majors gpa: float array of student gpa //In, Out, InOut? // Parameters: (in, in, in, in, in, in, in, in ) void OutputRecord ( long stuID, int size, const long id, const string firstName, const string lastName, const char gender, const string major, const float gpa );

Output Record // // The function takes the student id and total number of records // as inputs. If there exists a record with that student id, // the function will print out the student's id, name, gender, major, // and gpa; otherwise, it will print a "Not found" message. // Parameters: (in, in, in, in, in, in, in, in ) // void OutputRecord ( long stuID, int size, const long id[], const string firstName[], const string lastName[], const char gender[], const string major[], const float gpa[] ) { int index; index = SearchID ( id, size, stuID ); if ( index != -1 ) { cout << "Name : " << firstName[index] << " " << lastName[index] << endl << "Gender: " << gender[index] << endl << "Major : " << major[index] << endl << "GPA : " << gpa[index] << endl; } else cout << "The student record does not exist!" << endl; }

int main() { long id [MAX_STUDENTS]; string firstName[MAX_STUDENTS]; string lastName [MAX_STUDENTS]; char gender [MAX_STUDENTS]; string major [MAX_STUDENTS]; float gpa [MAX_STUDENTS]; int count; int index; long studentID; count = ReadRecord ( MAX_STUDENTS, id, firstName, lastName, gender, major, gpa ); cout << "Record reading finished. " << count << " records read." << endl; cout << endl << "Please enter the student ID [enter -1 to end]: "; cin >> studentID; while ( studentID != -1 ) { OutputRecord ( studentID, count, id, firstName, lastName, gender, major, gpa ); cout << endl << "Please enter the student ID [enter -1 to end]: "; cin >> studentID; } cout << endl << "Thank you for using the system. Bye." << endl; return 0; }

Summary Declare an array Operations on array elements Pass an array as a function parameter: In or Out Linear search Parallel arrays FOR loop