登金陵鳳凰臺 ~李白 鳳凰臺上鳳凰遊, 鳳去臺空江自流。 吳宮花草埋幽徑, 晉代衣冠成古丘。 三山半落青山外, 二水中分白鷺洲。

Slides:



Advertisements
Similar presentations
Pointers and Strings. Introduction Pointers –Powerful, but difficult to master –Simulate call-by-reference –Close relationship with arrays and strings.
Advertisements

Chapter 10.
Overview creating your own functions calling your own functions.
 2003 Prentice Hall, Inc. All rights reserved. 1 Arrays –Structures of related data items –Static entity (same size throughout program) A few types –Pointer-based.
Data types and variables
Chapter 2 Data Types, Declarations, and Displays
Basic Elements of C++ Chapter 2.
 2003 Prentice Hall, Inc. All rights reserved. 1 Introduction to C++ Programming Outline Introduction to C++ Programming A Simple Program: Printing a.
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.
1 Chapter 8 Destructor & Operator Overloading. 2 Destructor  A destructor is a function that is called when an object is no longer required. A constructor.
1 CISC181 Introduction to Computer Science Dr. McCoy Lecture 7 Clicker Questions September 22, 2009.
 2000 Deitel & Associates, Inc. All rights reserved Introduction Pointers –Powerful, but difficult to master –Simulate call-by-reference –Close.
1 Lecture 14 Functions Functions with Empty Parameter Lists Empty parameter lists  void or leave parameter list empty  Indicates function takes.
CHAPTER 10 ARRAYS AND FUNCTIONS Prepared by: Lec. Ghader Kurdi.
C++ / G4MICE Course Session 1 - Introduction Edit text files in a UNIX environment. Use the g++ compiler to compile a single C++ file. Understand the C++
1 Lecture 12 Pointers and Strings Section 5.4, ,
DCT1063 Programming 2 CHAPTER 1 POINTERS Mohd Nazri Bin Ibrahim Faculty of Computer, Media & Technology TATi University College
 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 3 - Functions Outline 3.15Functions with Empty Parameter Lists 3.16Inline Functions 3.17References.
1 CISC181 Introduction to Computer Science Dr. McCoy Lecture 2 September 3, 2009.
 2003 Prentice Hall, Inc. All rights reserved Basics of a Typical C++ Environment C++ systems –Program-development environment –Language –C++
1 Lecture 4: Part1 Arrays Introduction Arrays  Structures of related data items  Static entity (same size throughout program)
 2000 Prentice Hall, Inc. All rights reserved Program Components in C++ Function definitions –Only written once –These statements are hidden from.
C++ Programming Lecture 13 Functions – Part V By Ghada Al-Mashaqbeh The Hashemite University Computer Engineering Department.
Chapter 2 Variables and Constants. Objectives Explain the different integer variable types used in C++. Declare, name, and initialize variables. Use character.
登金陵鳳凰臺 ~李白 鳳凰臺上鳳凰遊, 鳳去臺空江自流。 吳宮花草埋幽徑, 晉代衣冠成古丘。 三山半落青山外, 二水中分白鷺洲。
Bill Tucker Austin Community College COSC 1315
© by Pearson Education, Inc. All Rights Reserved.
Chapter 1.2 Introduction to C++ Programming
Chapter Topics The Basics of a C++ Program Data Types
Chapter 1.2 Introduction to C++ Programming
Chapter 1.2 Introduction to C++ Programming
Introduction to C++ Programming
Introduction to C++ Programming
Chapter 2 Introduction to C++ Programming
Chapter 1.2 Introduction to C++ Programming
Arrays Outline 1 Introduction 2 Arrays 3 Declaring Arrays
Arrays Arrays exist in almost every computer language.
Basic Elements of C++.
CSC113: Computer Programming (Theory = 03, Lab = 01)
Chapter 6: Functions Copyright © 2010 Pearson Education, Inc. Publishing as Pearson Addison-Wesley.
Lecture 6 C++ Programming
User-Defined Functions
Basic Elements of C++ Chapter 2.
Arrays and Strings Chapter 9.
Introduction to C++ Programming
Arrays Kingdom of Saudi Arabia
Pointers and Pointer-Based Strings
Review for Final Exam.
Pointers Kingdom of Saudi Arabia
CSE 100 Data Types Declarations Displays.
Introduction to C++ Programming
Variables have attributes
Review for Final Exam.
C++ Pointers and Strings
Engineering Problem Solving with C++ An Object Based Approach
Chapter 15 - C++ As A "Better C"
Arrays Arrays A few types Structures of related data items
Fundamental Programming
CS250 Introduction to Computer Science II
C++ Programming Basics
Lecture 2 Arrays & Pointers September 7, 2004
CISC181 Introduction to Computer Science Dr
登金陵鳳凰臺 ~李白 鳳凰臺上鳳凰遊, 鳳去臺空江自流。 吳宮花草埋幽徑, 晉代衣冠成古丘。 三山半落青山外, 二水中分白鷺洲。
各題答對人數.
Chapter 8 (Part 2) Destructor & Operator Overloading (P.331)
送孟浩然之廣陵 ~李白 故人西辭黃鶴樓, 煙花三月下揚州。 孤帆遠影碧空盡, 惟見長江天際流。.
Variables and Constants
Video: The Sound of Raining
4.1 Introduction Arrays A few types Structures of related data items
Presentation transcript:

登金陵鳳凰臺 ~李白 鳳凰臺上鳳凰遊, 鳳去臺空江自流。 吳宮花草埋幽徑, 晉代衣冠成古丘。 三山半落青山外, 二水中分白鷺洲。 登金陵鳳凰臺 ~李白 鳳凰臺上鳳凰遊, 鳳去臺空江自流。 吳宮花草埋幽徑, 晉代衣冠成古丘。 三山半落青山外, 二水中分白鷺洲。 總為浮雲能蔽日, 長安不見使人愁。

Chapter 6 More about Functions

Initializing Function Parameters (P.302) You may declare the default value of some parameters: void showit(char msg[] = "I know the default!"); When you omit the argument in calling the function, the default value will be supplied automatically. showit("Today is Wednesday."); showit(); Ex6_03.cpp on P.302 Note that in P.303: Only the last argument(s) can be omitted. do_it(30, 30) is legal. do_it(30, , 30, 30) is illegal.

Exercise: TETRIS (3) Modify your TETRIS program so that when the function draw_block(i) and erase_block(i) are invoked without specifying the x and y coordinates, the default values would be x=0 and y=0. Add a segment of code in your main program (before the loop which shows the falling down blocks) to test it. for (i=1; i<=7; i++) { draw_block(i); refresh(); usleep(1000000); erase_block(i); }

Function Overloading (P.310) #include <iostream> using std::endl; using std::cout; void print(int i) { cout << " Here is int " << i << endl; } void print(double f) { cout << " Here is float " << f << endl; void print(const char* c) { // Use of the const Modifier cout << " Here is char* " << c << endl; int main() { print(10); print(10.10); print("ten");

Function Overloading (P.310) Normally, we need three distinct functions to handle three different data types: int max_int(int array[], int len); long max_long(long array[], int len); double max_double(double array[], int len); Function overloading allows you to use the same function name for defining several functions as long as they each have different parameter lists. When the function is called, the compiler chooses the correct version according to the list of arguments you supply.

Ex6_07.cpp on P.311 The following functions share a common name, but have a different parameter list: int max(int array[], int len); long max(long array[], int len); double max(double array[], int len); Three overloaded functions of max() In main(), C compiler inspect the argument list to choose different version of functions.

Signature Overloaded functions can be differentiated by having corresponding parameters of different types, or having a different number of parameters. The signature of a function is determined by its name and its parameter list. All functions in a program must have unique signatures. The following example is not valid overloading double max(long array[], int len); long max(long array[], int len); A different return type does not distinguish a function, if the signatures are the same.

If Signature Is Not Unique … #include <iostream> using std::cout; using std::endl; int sum(int a, float b) { return a+ static_cast<int>(b); } float sum(int a, float b) { return static_cast<float>(a) + b; } int main() { cout << sum(1, 2.5) << endl; return 0; } Which version do you invoke?

Ex: Function Overloading Define two functions display(char []) and display(char [], char[]). The first function will display the argument with a newline character. The second function will display a horizontal separator composed of equal signs ('='), then display an argument in a line, and end with a horizontal separator again. Test your functions with the following main program: int main() { char first[] = "C programming"; char second[] = "is interesting"; display(first); display(first, second); return 0; } The output should be C programming ============== C programming is interesting ==============

Example: Playing Cards Playing cards have four suits: Spade () Heart () Diamond () Club () There are 13 ranks in a suit: 2, 3, 4, 5, 6, 7, 8, 9, 10, J, Q, K, A ex3_suit.cpp

Use 0..51 to Represent 52 Cards 2 3 4 5 6 7 8 9 T J Q K A ======================================  0 1 2 3 4 5 6 7 8 9 10 11 12  13 14 15 16 17 18 19 20 21 22 23 24 25  26 27 28 29 30 31 32 33 34 35 36 37 38  39 40 41 42 43 44 45 46 47 48 49 50 51 ex5_cards.cpp Suit     ASCII code 3 4 5 6

Randomly Get 5 Cards An intuitive method is to randomly choose a number between 0..51, and repeat this action for 5 times for (int i = 0; i < 5; i++ ) cout << rand() % 52 << endl; print_card.cpp print_card_with_seed.cpp Sooner or later, you will see duplicate cards!

Pointers (Chapter 4) A pointer stores an address which points to a variable of some type A single pointer can point to different variables at different times a p b p = &a; *p = a p = &b; *p = b c p = &c; *p = c

Pointers to Functions (P.296) A pointer to functions also provide you the flexibility. It will call the function whose address was last assigned to the pointer. A pointer to a function must contain The memory address of the function The parameter list The return type

Declaring Pointers to Functions double (*pfun) (char*, int); The parentheses around the pointer name, pfun, and the asterisk are necessary. Otherwise, double *pfun (char*, int) would be a function returning a pointer to a double value. long sum(long num1, long num2); long (*pfun)(long, long) = sum; long product(long, long); pfun = product;

Ex6_01.cpp on P.297

A Simpler Example As a matter of fact, I think Ex6_01.cpp is too complicated. I prefer the following example: pdo_it = product; cout << pdo_it(3,5) << endl; pdo_it = sum;

A Pointer to a Function as an Argument Ex6_02.cpp on P.300 int main(void) { double array[] = { 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0 }; int len(sizeof array/sizeof array[0]); cout << endl << "Sum of squares = " << sumarray(array, len, squared); cout << endl << "Sum of cubes = " << sumarray(array, len, cubed); cout << endl; return 0; }

sumarray() double sumarry(double array[], int len, double (*pfun) (double)) { double total(0.0); for (int i=0; i<len; i++) total += pfun(array[i]); return total; }

Arrays of Pointers to Functions double sum(double, double); double product(double, double); double difference(double, double); double (*pfun[3]) (double, double) = { sum, product, difference } ; pfun[1](2.5, 3.5); product(2.5, 3.5) (*pfun)(2.5, 3.5); sum(2.5, 3.5); (*(pfun+2)) (2.5, 3.5); difference(2.5, 3.5)

HW: print_a_card() print_a_card_in_chinese() print_cards() sort_card()

Case Study: Implementing a Calculator Goal Design a program which acts as a calculator. It will take an arithmetic expression, evaluate it, and print out the result. For example, taking the input string “2 * 3.14159 * 12.6 * 12.6 /2 + 25.2 * 25.2” will obtain the result “1133.0”. To make it simple at the first stage, The whole computation must be entered in a single line. Spaces are allowed to be placed anywhere. Parentheses are not allowed in the expression. Only unsigned numbers are recognized.

Step 1: Eliminating Blanks from a String

An Intuitive Code for Eliminating Blanks #include <iostream> using std::cout; using std::endl; int main() { const int MAX = 80; char str1[MAX] = "NCNU is a good university."; char str2[MAX]; int i=0, j=0; do { if (str1[i] != ' ') str2[j++] = str1[i]; } while (str1[i++] != '\0'); cout << str2 << endl; return 0; }

P.322 Now, we obtain an expression with no embedding spaces. // Function to eliminate spaces from a string void eatspaces(char* str) { int i = 0; // ‘Copy to’ index to string int j = 0; // ‘Copy from’ index to string while ((*(str + i) = *(str + j++)) != ‘\0’) if (*(str + i) != ‘ ‘) i++; return; } Now, we obtain an expression with no embedding spaces.

Step 2: Evaluating an Expression expression: term addop term addop … term

Breaking Down an Expression into Terms and Numbers

Handling addop T F T F T F Get value of the first term Set expression value to value of first term Next character is ‘\0’ T F T Next character is ‘-’ Subtract value of next term from expression value F T Next character is ‘+’ Add value of next term from expression value F ERROR Return expression value

double expr(char* str) { double value = 0.0; int index = 0; value = term(str, index); for (;;) switch (*(str + index++)) case ‘\0’: return value; case ‘-’: value -= term(str, index); case ‘+’: value += term(str, index); default: cout << endl << “Arrrgh!*#!! There’s an error” << endl; exit(1); }

Getting the value of a Term (P.325) // Function to get the value of a term double term(char* str, int& index) { double value(0.0); // Somewhere to accumulate the result value = number(str, index); // Get the first number in the term // Loop as long as we have a good operator while (true) if (*(str + index) == '*') // If it's multiply, value *= number(str, ++index); // multiply by next number else if (*(str + index) == '/') // If it's divide, value /= number(str, ++index); // divide by next number else break; } return value;

Analyzing a Number

double number(char* str, int& index) { double value = 0.0; while (isdigit(*(str + index))) value = 10 * value + ( *(str + index++) – ‘0’); if (*(str + index) != ‘.’) return value; double factor = 1.0; while (isdigit(*(str + (++index)))) factor *= 0.1; value = value + ( *(str + index) – ‘0’) * factor; }

Handling the fractional part after the decimal point

Putting the Program Together P.330 Ex6_10.cpp #include <iostream> // For stream input/output #include <cstdlib> // For exit() function #include <cctype> // For isdigit() function Use cin.getline() so that the input string can contain spaces. See P.175

Exercise: Modify number() Implement the simple calculator defined in P.318—336. Modify the number() function defined in P.327 so that it will take hexadecimal strings as input. The return type will thus become an integer. You may test the modified program by providing an input string “A + B”, which should result in “15”. Another expression “B – A” will result in “1”.