 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 15 - Class string and String Stream Processing Outline 15.1 Introduction 15.2 string Assignment.

Slides:



Advertisements
Similar presentations
LECTURE 17 C++ Strings 18. 2Strings Creating String Objects 18 C-string C++ - string \0 Array of chars that is null terminated (‘\0’). Object.
Advertisements

 2003 Prentice Hall, Inc. All rights reserved Fundamentals of Characters and Strings Character constant –Integer value represented as character.
Strings.
Copyright © 2014, 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 12: More on C-Strings and the string Class Starting Out with.
Pointers and Strings. Introduction Pointers –Powerful, but difficult to master –Simulate call-by-reference –Close relationship with arrays and strings.
Chapter 10.
 2000 Deitel & Associates, Inc. All rights reserved. Chapter 19 - Class string and Stream Processing Outline 19.1Introduction 19.2 string Assignment and.
Today’s Class Class string –The basics –Assignment –Concatenation –Compare & swap –Find –Conversion to C-style char * strings –Iterators.
 2006 Pearson Education, Inc. All rights reserved Class string and String Stream Processing.
Introduction to Data Structure, Spring 2007 Slide- 1 California State University, Fresno Introduction to Data Structure Standard Template Library Ming.
 2003 Prentice Hall, Inc. All rights reserved Introduction Arrays –Structures of related data items –Static entity (same size throughout program)
The Standard String Class Is actually a template: –typedef basic_string string This means you can have strings of things other than chars.
計算機概論實習 How to Use string Template class basic_string String manipulation (copying, searching, etc.) typedef basic_string string; Also typedef.
 2006 Pearson Education, Inc. All rights reserved Class string and String Stream Processing.
 2003 Prentice Hall, Inc. All rights reserved. 1 Sorting Arrays Sorting data –Important computing application –Virtually every organization must sort.
 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.
C++ standard strings. Standard library of C++ language STL STL (The main part of standard library of C++ language) Stream classes Stream classes String.
 2003 Prentice Hall, Inc. All rights reserved. 1 IS 0020 Program Design and Software Tools Introduction to C++ Programming Lecture 3 Arrays & Pointers.
 2003 Prentice Hall, Inc. All rights reserved. 1 Introduction to C++ Programming Outline Introduction to C++ Programming A Simple Program: Printing a.
CSIS 123A Lecture 6 Strings & Dynamic Memory. Introduction To The string Class Must include –Part of the std library You can declare an instance like.
C++ String Class. Outline  String Initialization  Basic Operations  Comparisons  Substrings  Swapping Strings  String Size  Finding Strings and.
 2003 Prentice Hall, Inc. All rights reserved. 1 Arrays Outline Examples Using Arrays Passing arrays to functions Class GradeBook: store student grades.
CS Midterm Study Guide Fall General topics Definitions and rules Technical names of things Syntax of C++ constructs Meaning of C++ constructs.
 2003 Prentice Hall, Inc. All rights reserved. 1 Arrays Outline Introduction Arrays Declaring Arrays Examples Using Arrays.
 2008 Pearson Education, Inc. All rights reserved Pointers and Pointer-Based Strings.
Chapter 13 – C++ String Class. String objects u Do not need to specify size of string object –C++ keeps track of size of text –C++ expands memory region.
1 CISC181 Introduction to Computer Science Dr. McCoy Lecture 13 October 13, 2009.
 2000 Deitel & Associates, Inc. All rights reserved Introduction Pointers –Powerful, but difficult to master –Simulate call-by-reference –Close.
 2003 Prentice Hall, Inc. All rights reserved.m ECE 2552 Dr. Këpuska based on Dr. S. Kozaitis Summer Chapter 15 - Class string and String Stream.
 2000 Prentice Hall, Inc. All rights reserved. Chapter 21 - C++ Stream Input/Output Basics Outline 21.1Introduction 21.2Streams Iostream Library.
String Class. C-style and C++ string Classes C-style strings, called C-strings, consist of characters stored in an array ( we’ll look at them later) C++
1 Character Strings (Cstrings) Reference: CS215 textbook pages
C++ String Class nalhareqi©2012. string u The string is any sequence of characters u To use strings, you need to include the header u The string is one.
String Class Mohamed Shehata 1020: Introduction to Programming.
SMIE-121 Software Design II School of Mobile Information Engineering, Sun Yat-sen University Lecture.
 2003 Prentice Hall, Inc. All rights reserved. 1 Pointers and Strings Outline Introduction Pointer Variable Declarations and Initialization Pointer Operators.
 2008 Pearson Education, Inc. All rights reserved. 1 Arrays and Vectors.
Arrays, Vectors, and Strings Allocation and referencing.
 2003 Prentice Hall, Inc. All rights reserved. 5.11Function Pointers Pointers to functions –Contain address of function –Similar to how array name is.
 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 5 - Pointers and Strings Outline 5.1 Introduction 5.2 Pointer Variable Declarations and Initialization.
 2003 Prentice Hall, Inc. All rights reserved. 11 Fundamentals of Characters and Strings Character constant –Integer value of a character –Single quotes.
C++ STRINGS ● string is part of the Standard C++ Library ● new stuff: ● cin : standard input stream (normally the keyboard) of type istream. ● >> operator.
Chapter 11 Standard C++ Strings and File I/O Dept of Computer Engineering Khon Kaen University.
C++ How to Program, 9/e © by Pearson Education, Inc. All Rights Reserved.
C++ Programming Lecture 19 Strings The Hashemite University Computer Engineering Department (Adapted from the textbook slides)
 2003 Prentice Hall, Inc. All rights reserved. 1 Lecture 5: Pointer Outline Chapter 5 Pointer continue Call by reference Pointer arithmatic Debugging.
1 CISC181 Introduction to Computer Science Dr. McCoy Lecture 2 September 3, 2009.
C++ Programming Lecture 14 Arrays – Part I The Hashemite University Computer Engineering Department (Adapted from the textbook slides)
 2000 Prentice Hall, Inc. All rights reserved. 1 Chapter 4 - Arrays Outline 4.1Introduction 4.2Arrays 4.3Declaring Arrays 4.4Examples Using Arrays 4.5Passing.
 2003 Prentice Hall, Inc. All rights reserved vector Sequence Container Declarations –std::vector v; type : int, float, etc. Iterators –std::vector.
 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)
Strings.
2008YeungNam Univ. SE Lab. 1  I n n amespace std : t ypedef basic_string string ; Type wchar_t for 16bit UNICODE. A. String near-containers  I.
Chapter 1.2 Introduction to C++ Programming
Chapter 1.2 Introduction to C++ Programming
Chapter 1.2 Introduction to C++ Programming
Class string and String Stream Processing: A Deeper Look
Remark: Data Type of Array Name
C++ STRINGS string is part of the Standard C++ Library
Operator Overloading; String and Array Objects
10.1 Character Testing.
String class and its objects
Class string and String Stream Processing
Arrays Arrays A few types Structures of related data items
Today’s Objectives 28-Jun-2006 Announcements
Chapter 15 - Class string and String Stream Processing
character manipulation
4.1 Introduction Arrays A few types Structures of related data items
Chapter 12: More on C-Strings and the string Class
Presentation transcript:

 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 15 - Class string and String Stream Processing Outline 15.1 Introduction 15.2 string Assignment and Concatenation 15.3 Comparing strings 15.4 Substrings 15.5 Swapping strings 15.6 string Characteristics 15.7 Finding Strings and Characters in a string 15.8 Replacing Characters in a string 15.9 Inserting Characters into a string Conversion to C-Style char * Strings Iterators String Stream Processing

 2003 Prentice Hall, Inc. All rights reserved Introduction Template class basic_string –String manipulation (copying, searching, etc.) typedef basic_string string; Also typedef for wchar_t –Include string initialization –string s1( "Hello" ); –string s2( 8, 'x' ); 8 'x' characters –string month = "March" Implicitly calls constructor

 2003 Prentice Hall, Inc. All rights reserved Introduction No conversion from int or char –The following definitions are errors string error1 = 'c'; string error2( 'u' ); string error3 = 22; string error4( 8 ); –However, can assign to one char if declared s = 'n';

 2003 Prentice Hall, Inc. All rights reserved Introduction string features –Not necessarily null terminated –length member function: s1.length() –Use [] to access individual characters: s1[0] 0 to length-1 –string not a pointer –Many member functions take start position and length If length argument too large, max chosen –Stream extraction cin >> stringObject; getline( cin, s) –Delimited by newline

 2003 Prentice Hall, Inc. All rights reserved string Assignment and Concatenation Assignment –s2 = s1; Makes a separate copy –s2.assign(s1); Same as s2 = s1; –myString.assign(s, start, N); Copies N characters from s, beginning at index start –Individual characters s2[0] = s3[2];

 2003 Prentice Hall, Inc. All rights reserved string Assignment and Concatenation Range checking –s3.at( index ); Returns character at index Can throw out_of_range exception –[] has no range checking Concatenation –s3.append( "pet" ); –s3 += "pet"; Both add "pet" to end of s3 –s3.append( s1, start, N ); Appends N characters from s1, beginning at index start

 2003 Prentice Hall, Inc. All rights reserved. Outline 7 fig15_01.cpp (1 of 3) 1 // Fig. 15.1: fig15_01.cpp 2 // Demonstrating string assignment and concatenation. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include 9 10 using std::string; int main() 13 { 14 string string1( "cat" ); 15 string string2; 16 string string3; string2 = string1; // assign string1 to string2 19 string3.assign( string1 ); // assign string1 to string3 20 cout << "string1: " << string1 << "\nstring2: " << string2 21 << "\nstring3: " << string3 << "\n\n"; 22 String initialization and assignment. Output string1: cat string2: cat string3: cat

 2003 Prentice Hall, Inc. All rights reserved. Outline 8 fig15_01.cpp (2 of 3) 23 // modify string2 and string3 24 string2[ 0 ] = string3[ 2 ] = 'r'; cout << "After modification of string2 and string3:\n" 27 << "string1: " << string1 << "\nstring2: " << string2 28 << "\nstring3: "; // demonstrating member function at 31 for ( int i = 0; i < string3.length(); i++ ) 32 cout << string3.at( i ); // declare string4 and string5 35 string string4( string1 + "apult" ); 36 string string5; // overloaded += 39 string3 += "pet"; // create "carpet" 40 string1.append( "acomb" ); // create "catacomb" // append subscript locations 4 through end of string1 to 43 // create string "comb" (string5 was initially empty) 44 string5.append( string1, 4, string1.length() ); cout << "\n\nAfter concatenation:\nstring1: " << string1 47 << "\nstring2: " << string2 << "\nstring3: " 48 << string3 << "\nstring4: " << string4 49 << "\nstring5: " << string5 << endl; 50 After modification of string2 and string3: string1: cat string2: rat string3: car Note use of member function at instead of []. After concatenation: string1: catacomb string2: rat string3: carpet string4: catapult string5: comb

 2003 Prentice Hall, Inc. All rights reserved. Outline 9 fig15_01.cpp (3 of 3) fig15_01.cpp output (1 of 1) string1: cat string2: cat string3: cat After modification of string2 and string3: string1: cat string2: rat string3: car After concatenation: string1: catacomb string2: rat string3: carpet string4: catapult string5: comb 51 return 0; } // end main

 2003 Prentice Hall, Inc. All rights reserved Comparing strings Overloaded operators –==, !=,, = –Return bool s1.compare(s2) –Returns positive if s1 lexicographically greater Compares letter by letter 'B' lexicographically greater than 'A' –Returns negative if less, zero if equal –s1.compare(start, length, s2, start, length) Compare portions of s1 and s2 –s1.compare(start, length, s2) Compare portion of s1 with all of s2

 2003 Prentice Hall, Inc. All rights reserved. Outline 11 fig15_02.cpp (1 of 4) 1 // Fig. 15.2: fig15_02.cpp 2 // Demonstrating string comparison capabilities. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include 9 10 using std::string; int main() 13 { 14 string string1( "Testing the comparison functions." ); 15 string string2( "Hello" ); 16 string string3( "stinger" ); 17 string string4( string2 ); 18

 2003 Prentice Hall, Inc. All rights reserved. Outline 12 fig15_02.cpp (2 of 4) 19 cout << "string1: " << string1 << "\nstring2: " << string2 20 << "\nstring3: " << string3 << "\nstring4: " << string4 21 << "\n\n"; // comparing string1 and string4 24 if ( string1 == string4 ) 25 cout << "string1 == string4\n"; 26 else { // string1 != string4 27 if ( string1 > string4 ) 28 cout string4\n"; 29 else // string1 < string4 30 cout << "string1 < string4\n"; 31 } // comparing string1 and string2 34 int result = string1.compare( string2 ); if ( result == 0 ) 37 cout << "string1.compare( string2 ) == 0\n"; 38 else // result != 0 39 if ( result > 0 ) 40 cout 0\n"; 41 else // result < 0 42 cout << "string1.compare( string2 ) < 0\n"; 43 string1: Testing the comparison functions. string2: Hello string3: stinger string4: Hello string1 > string4 Note use of overloaded == operator.

 2003 Prentice Hall, Inc. All rights reserved. Outline 13 fig15_02.cpp (3 of 4) 44 // comparing string1 (elements 2-5) and string3 (elements 0-5) 45 result = string1.compare( 2, 5, string3, 0, 5 ); if ( result == 0 ) 48 cout << "string1.compare( 2, 5, string3, 0, 5 ) == 0\n"; 49 else // result != 0 50 if ( result > 0 ) 51 cout 0\n"; 52 else // result < 0 53 cout << "string1.compare( 2, 5, string3, 0, 5 ) < 0\n"; // comparing string2 and string4 56 result = string4.compare( 0, string2.length(), string2 ); if ( result == 0 ) 59 cout << "string4.compare( 0, string2.length(), " 60 << "string2 ) == 0" << endl; 61 else // result != 0 62 if ( result > 0 ) 63 cout << "string4.compare( 0, string2.length(), " 64 0" << endl; 65 else // result < 0 66 cout << "string4.compare( 0, string2.length(), " 67 << "string2 ) < 0" << endl; 68 Note use of compare.

 2003 Prentice Hall, Inc. All rights reserved. Outline 14 fig15_02.cpp (4 of 4) fig15_02.cpp output (1 of 1) 69 // comparing string2 and string4 70 result = string2.compare( 0, 3, string4 ); if ( result == 0 ) 73 cout << "string2.compare( 0, 3, string4 ) == 0" << endl; 74 else // result != 0 75 if ( result > 0 ) 76 cout 0" << endl; 77 else // result < 0 78 cout << "string2.compare( 0, 3, string4 ) < 0" << endl; return 0; } // end main string1: Testing the comparison functions. string2: Hello string3: stinger string4: Hello string1 > string4 string1.compare( string2 ) > 0 string1.compare( 2, 5, string3, 0, 5 ) == 0 string4.compare( 0, string2.length(), string2 ) == 0 string2.compare( 0, 3, string4 ) < 0

 2003 Prentice Hall, Inc. All rights reserved Substrings Function substr gets substring –s1.substr( start, N ); –Gets N characters, beginning with index start –Returns substring

 2003 Prentice Hall, Inc. All rights reserved. Outline 16 fig15_03.cpp (1 of 1) fig15_03.cpp output (1 of 1) 1 // Fig. 15.3: fig15_03.cpp 2 // Demonstrating string member function substr. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include 9 10 using std::string; int main() 13 { 14 string string1( "The airplane landed on time." ); // retrieve substring "plane" which 17 // begins at subscript 7 and consists of 5 elements 18 cout << string1.substr( 7, 5 ) << endl; return 0; } // end main plane Note usage of substr.

 2003 Prentice Hall, Inc. All rights reserved Swapping strings s1.swap(s2); –Switch contents of two strings

 2003 Prentice Hall, Inc. All rights reserved. Outline 18 fig15_04.cpp (1 of 1) 1 // Fig. 15.4: fig15_04.cpp 2 // Using the swap function to swap two strings. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include 9 10 using std::string; int main() 13 { 14 string first( "one" ); 15 string second( "two" ); // output strings 18 cout << "Before swap:\n first: " << first 19 << "\nsecond: " << second; first.swap( second ); // swap strings cout << "\n\nAfter swap:\n first: " << first 24 << "\nsecond: " << second << endl; return 0; } // end main Call swap.

 2003 Prentice Hall, Inc. All rights reserved. Outline 19 fig15_04.cpp output (1 of 1) Before swap: first: one second: two After swap: first: two second: one

 2003 Prentice Hall, Inc. All rights reserved string Characteristics Member functions –s1.size() and s1.length() Number of characters in string –s1.capacity() Number of elements that can be stored without reallocation –s1.max_size() Maximum possible string size –s1.empty() Returns true if empty –s1.resize(newlength) Resizes string to newlength

 2003 Prentice Hall, Inc. All rights reserved. Outline 21 fig15_05.cpp (1 of 3) 1 // Fig. 15.5: fig15_05.cpp 2 // Demonstrating member functions related to size and capacity. 3 #include 4 5 using std::cout; 6 using std::endl; 7 using std::cin; 8 using std::boolalpha; 9 10 #include using std::string; void printStatistics( const string & ); int main() 17 { 18 string string1; cout << "Statistics before input:\n" << boolalpha; 21 printStatistics( string1 ); // read in "tomato" 24 cout << "\n\nEnter a string: "; 25 cin >> string1; // delimited by whitespace 26 cout << "The string entered was: " << string1;

 2003 Prentice Hall, Inc. All rights reserved. Outline 22 fig15_05.cpp (2 of 3) cout << "\nStatistics after input:\n"; 29 printStatistics( string1 ); // read in "soup" 32 cin >> string1; // delimited by whitespace 33 cout << "\n\nThe remaining string is: " << string1 << endl; 34 printStatistics( string1 ); // append 46 characters to string1 37 string1 += " abcdefghijklmnopqrstuvwxyz "; 38 cout << "\n\nstring1 is now: " << string1 << endl; 39 printStatistics( string1 ); // add 10 elements to string1 42 string1.resize( string1.length() + 10 ); 43 cout << "\n\nStats after resizing by (length + 10):\n"; 44 printStatistics( string1 ); cout << endl; 47 return 0; } // end main 50 Resize string.

 2003 Prentice Hall, Inc. All rights reserved. Outline 23 fig15_05.cpp (3 of 3) fig15_05.cpp output (1 of 2) 51 // display string statistics 52 void printStatistics( const string &stringRef ) 53 { 54 cout << "capacity: " << stringRef.capacity() 55 << "\nmax size: " << stringRef.max_size() 56 << "\nsize: " << stringRef.size() 57 << "\nlength: " << stringRef.length() 58 << "\nempty: " << stringRef.empty(); } // end printStatistics Statistics before input: capacity: 0 max size: size: 0 length: 0 empty: true Enter a string: tomato soup The string entered was: tomato Statistics after input: capacity: 31 max size: size: 6 length: 6 empty: false Display various string characteristics.

 2003 Prentice Hall, Inc. All rights reserved. Outline 24 fig15_05.cpp output (2 of 2) The remaining string is: soup capacity: 31 max size: size: 4 length: 4 empty: false string1 is now: soup abcdefghijklmnopqrstuvwxyz capacity: 63 max size: size: 50 length: 50 empty: false Stats after resizing by (length + 10): capacity: 63 max size: size: 60 length: 60 empty: false

 2003 Prentice Hall, Inc. All rights reserved Finding Strings and Characters in a string Find functions –If found, index returned –If not found, string::npos returned Public static constant in class string –s1.find( s2 ) –s1.rfind( s2 ) Searches right-to-left –s1.find_first_of( s2 ) Returns first occurrence of any character in s2 s1.find_frist_of( "abcd" ) –Returns index of first 'a', 'b', 'c' or 'd'

 2003 Prentice Hall, Inc. All rights reserved Finding Strings and Characters in a string Find functions –s1.find_last_of( s2 ) Finds last occurrence of any character in s2 –s1.find_first_not_of( s2 ) Finds first character NOT in s2 –s1.find_last_not_of( s2 ) Finds last character NOT in s2

 2003 Prentice Hall, Inc. All rights reserved. Outline 27 fig15_06.cpp (1 of 3) 1 // Fig. 15.6: fig15_06.cpp 2 // Demonstrating the string find member functions 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include 9 10 using std::string; int main() 13 { 14 string string1( "noon is 12 p.m." ); 15 int location; // find "is" at location 5 18 cout << "Original string:\n" << string1 19 << "\n\n(find) \"is\" was found at: " 20 << string1.find( "is" ) 21 << "\n(rfind) \"is\" was found at: " 22 << string1.rfind( "is" ); // find 'o' at location 1 25 location = string1.find_first_of( "misop" ); Find first occurrence of m, i, s, o or p. Note call to function find.

 2003 Prentice Hall, Inc. All rights reserved. Outline 28 fig15_06.cpp (2 of 3) cout << "\n\n(find_first_of) found '" << string1[ location ] 28 << "' from the group \"misop\" at: " 29 << location; // find 'm' at location location = string1.find_last_of( "misop" ); 33 cout << "\n\n(find_last_of) found '" << string1[ location ] 34 << "' from the group \"misop\" at: " 35 << location; // find '1' at location 8 38 location = string1.find_first_not_of( "noi spm" ); 39 cout << "\n\n(find_first_not_of) '" << string1[ location ] 40 << "' is not contained in \"noi spm\" and was found at:" 41 << location; // find '.' at location location = string1.find_first_not_of( "12noi spm" ); 45 cout << "\n\n(find_first_not_of) '" << string1[ location ] 46 << "' is not contained in \"12noi spm\" and was " 47 << "found at:" << location << endl; Calls to other find functions similar.

 2003 Prentice Hall, Inc. All rights reserved. Outline 29 fig15_06.cpp (3 of 3) fig15_06.cpp output (1 of 1) // search for characters not in string1 50 location = string1.find_first_not_of( "noon is 12 p.m." ); 51 cout << "\nfind_first_not_of(\"noon is 12 p.m.\")" 52 << " returned: " << location << endl; return 0; } // end main Original string: noon is 12 p.m. (find) "is" was found at: 5 (rfind) "is" was found at: 5 (find_first_of) found 'o' from the group "misop" at: 1 (find_last_of) found 'm' from the group "misop" at: 13 (find_first_not_of) '1' is not contained in "noi spm" and was found at:8 (find_first_not_of) '.' is not contained in "12noi spm" and was found at:12 find_first_not_of("noon is 12 p.m.") returned: -1

 2003 Prentice Hall, Inc. All rights reserved Replacing Characters in a string s1.erase( start ) –Erase from index start to end of string, including start Replace –s1.replace( begin, N, s2) begin : index in s1 to start replacing N : number of characters to replace s2 : replacement string –s1.replace( begin, N, s2, index, num ) index : element in s2 where replacement begins num : number of elements to use when replacing –Replacement can overwrite characters –string::npos represents max string length

 2003 Prentice Hall, Inc. All rights reserved. Outline 31 fig15_07.cpp (1 of 2) 1 // Fig. 15.7: fig15_07.cpp 2 // Demonstrating string member functions erase and replace. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include 9 10 using std::string; int main() 13 { 14 // compiler concatenates all parts into one string 15 string string1( "The values in any left subtree" 16 "\nare less than the value in the" 17 "\nparent node and the values in" 18 "\nany right subtree are greater" 19 "\nthan the value in the parent node" ); cout << "Original string:\n" << string1 << endl << endl; // remove all characters from (and including) location // through the end of string1 25 string1.erase( 62 ); 26

 2003 Prentice Hall, Inc. All rights reserved. Outline 32 fig15_07.cpp (2 of 2) 27 // output new string 28 cout << "Original string after erase:\n" << string1 29 << "\n\nAfter first replacement:\n"; // replace all spaces with period 32 int position = string1.find( " " ); while ( position != string::npos ) { 35 string1.replace( position, 1, "." ); 36 position = string1.find( " ", position + 1 ); 37 } // end while cout << string1 << "\n\nAfter second replacement:\n"; // replace all periods with two semicolons 42 // NOTE: this will overwrite characters 43 position = string1.find( "." ); while ( position != string::npos ) { 46 string1.replace( position, 2, "xxxxx;;yyy", 5, 2 ); 47 position = string1.find( ".", position + 1 ); 48 } // end while cout << string1 << endl; 51 return 0; } // end main Find each space and replace with a '.' Start each search at the next position. Replace all '.' with two semicolons (the two characters at index 5). string::npos represents max string length.

 2003 Prentice Hall, Inc. All rights reserved. Outline 33 fig15_07.cpp output (1 of 1) Original string: The values in any left subtree are less than the value in the parent node and the values in any right subtree are greater than the value in the parent node Original string after erase: The values in any left subtree are less than the value in the After first replacement: The.values.in.any.left.subtree are.less.than.the.value.in.the After second replacement: The;;alues;;n;;ny;;eft;;ubtree are;;ess;;han;;he;;alue;;n;;he

 2003 Prentice Hall, Inc. All rights reserved Inserting Characters into a string s1.insert( index, s2 ) –Inserts s2 before position index s1.insert( index, s2, index2, N ); –Inserts substring of s2 before position index –Substring is N characters, starting at index2

 2003 Prentice Hall, Inc. All rights reserved. Outline 35 fig15_08.cpp (1 of 2) 1 // Fig. 15.8: fig15_08.cpp 2 // Demonstrating class string insert member functions. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include 9 10 using std::string; int main() 13 { 14 string string1( "beginning end" ); 15 string string2( "middle " ); 16 string string3( " " ); 17 string string4( "xx" ); cout << "Initial strings:\nstring1: " << string1 20 << "\nstring2: " << string2 << "\nstring3: " << string3 21 << "\nstring4: " << string4 << "\n\n"; // insert "middle" at location 10 in string1 24 string1.insert( 10, string2 ); 25 Insert all of string2 before element 10.

 2003 Prentice Hall, Inc. All rights reserved. Outline 36 fig15_08.cpp (2 of 2) fig15_08.cpp output (1 of 1) 26 // insert "xx" at location 3 in string3 27 string3.insert( 3, string4, 0, string::npos ); cout << "Strings after insert:\nstring1: " << string1 30 << "\nstring2: " << string2 << "\nstring3: " << string3 31 << "\nstring4: " << string4 << endl; return 0; } // end main Initial strings: string1: beginning end string2: middle string3: string4: xx Strings after insert: string1: beginning middle end string2: middle string3: 123xx45678 string4: xx Insert all of string4 before index 3.

 2003 Prentice Hall, Inc. All rights reserved Conversion to C-Style char * Strings Conversion functions –string s not necessarily null-terminated –s1.copy( ptr, N, index ) Copies N characters into the array ptr Starts at location index Need to null terminate –s1.c_str() Returns const char * Null terminated –s1.data() Returns const char * NOT null-terminated

 2003 Prentice Hall, Inc. All rights reserved. Outline 38 fig15_09.cpp (1 of 2) 1 // Fig. 15.9: fig15_09.cpp 2 // Converting to C-style strings. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include 9 10 using std::string; int main() 13 { 14 string string1( "STRINGS" ); 15 const char *ptr1 = 0; 16 int length = string1.length(); 17 char *ptr2 = new char[ length + 1 ]; // including null // copy characters from string1 into allocated memory 20 string1.copy( ptr2, length, 0 ); 21 ptr2[ length ] = '\0'; // add null terminator // output 24 cout << "string s is " << string1 25 << "\nstring1 converted to a C-Style string is " 26 << string1.c_str() << "\nptr1 is "; Note calls to copy and c_str.

 2003 Prentice Hall, Inc. All rights reserved. Outline 39 fig15_09.cpp (2 of 2) fig15_09.cpp output (1 of 1) // Assign to pointer ptr1 the const char * returned by 29 // function data(). NOTE: this is a potentially dangerous 30 // assignment. If string1 is modified, pointer ptr1 can 31 // become invalid. 32 ptr1 = string1.data(); // output each character using pointer 35 for ( int i = 0; i < length; i++ ) 36 cout << *( ptr1 + i ); // use pointer arithmetic cout << "\nptr2 is " << ptr2 << endl; 39 delete [] ptr2; 40 return 0; } // end main string s is STRINGS string1 converted to a C-Style string is STRINGS ptr1 is STRINGS ptr2 is STRINGS

 2003 Prentice Hall, Inc. All rights reserved Iterators Iterators –Forwards and backwards traversal of strings –Access to individual characters –Similar to pointer operations –More coverage Chapter 20

 2003 Prentice Hall, Inc. All rights reserved Iterators Basic usage –Creation string::const_iterator i = s.begin(); const, cannot modify string (more Chapter 20) –Referencing *i; // reference character ++i; // traverse one character forward –Test for end of string i != s.end() end returns iterator after last element of s

 2003 Prentice Hall, Inc. All rights reserved. Outline 42 fig15_10.cpp (1 of 1) 1 // Fig : fig15_10.cpp 2 // Using an iterator to output a string. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include 9 10 using std::string; int main() 13 { 14 string string1( "Testing iterators" ); 15 string::const_iterator iterator1 = string1.begin(); cout << "string1 = " << string1 18 << "\n(Using iterator iterator1) string1 is: "; // iterate through string 21 while ( iterator1 != string1.end() ) { 22 cout << *iterator1; // dereference iterator to get char 23 ++iterator1; // advance iterator to next char 24 } // end while cout << endl; 27 return 0; } // end main Print each character using the iterator.

 2003 Prentice Hall, Inc. All rights reserved. Outline 43 fig15_10.cpp output (1 of 1) string1 = Testing iterators (Using iterator iterator1) string1 is: Testing iterators

 2003 Prentice Hall, Inc. All rights reserved String Stream Processing I/O of strings to and from memory –Called in-memory I/O or string stream processing –Classes istringstream (input from string) ostringstream (output to a string) and headers –Use string formatting to save data to memory

 2003 Prentice Hall, Inc. All rights reserved String Stream Processing String output –Ostringstream outputString; –outputString << s1 << s2; –Member function str Returns string that was output to memory outputString.str()

 2003 Prentice Hall, Inc. All rights reserved. Outline 46 fig15_11.cpp (1 of 2) 1 // Fig : fig15_11.cpp 2 // Using a dynamically allocated ostringstream object. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include 9 10 using std::string; #include using std::ostringstream; int main() 17 { 18 ostringstream outputString; // create ostringstream instance string string1( "Output of several data types " ); 21 string string2( "to an ostringstream object:" ); 22 string string3( "\n double: " ); 23 string string4( "\n int: " ); 24 string string5( "\naddress of int: " ); Create ostringstream object.

 2003 Prentice Hall, Inc. All rights reserved. Outline 47 fig15_11.cpp (2 of 2) double double1 = ; 27 int integer = 22; // output strings, double and int to outputString 30 outputString << string1 << string2 << string3 << double1 31 << string4 << integer << string5 << &integer; // call str to output contents 34 cout << "outputString contains:\n" << outputString.str(); // add additional characters and call str to output string 37 outputString << "\nmore characters added"; 38 cout << "\n\nafter additional stream insertions,\n" 39 << "outputString contains:\n" << outputString.str() 40 << endl; return 0; } // end main Output format just like to writing to cout.

 2003 Prentice Hall, Inc. All rights reserved. Outline 48 fig15_11.cpp output (1 of 1) outputString contains: Output of several data types to an ostringstream object: double: int: 22 address of int: 0012FE94 after additional stream insertions, outputString contains: Output of several data types to an ostringstream object: double: int: 22 address of int: 0012FE94 more characters added

 2003 Prentice Hall, Inc. All rights reserved String Stream Processing String input –istringstream inputString ( myString ); –inputString >> string1 >> string2 –Like reading from cin

 2003 Prentice Hall, Inc. All rights reserved. Outline 50 fig15_12.cpp (1 of 2) 1 // Fig : fig15_12.cpp 2 // Demonstrating input from an istringstream object. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include 9 10 using std::string; #include using std::istringstream; int main() 17 { 18 string input( "Input test A" ); 19 istringstream inputString( input ); 20 string string1; 21 string string2; 22 int integer; 23 double double1; 24 char character; 25 Create and initialize istringstream object.

 2003 Prentice Hall, Inc. All rights reserved. Outline 51 fig15_12.cpp (2 of 2) 26 inputString >> string1 >> string2 >> integer >> double1 27 >> character; cout << "The following items were extracted\n" 30 << "from the istringstream object:" 31 << "\nstring: " << string1 32 << "\nstring: " << string2 33 << "\n int: " << integer 34 << "\ndouble: " << double1 35 << "\n char: " << character; // attempt to read from empty stream 38 long value; inputString >> value; // test stream results 43 if ( inputString.good() ) 44 cout << "\n\nlong value is: " << value << endl; 45 else 46 cout << "\n\ninputString is empty" << endl; return 0; } // end main Read data into variables. good returns 1 if can still read data (no EOF, bad bits, etc). In this case, there is no data, so the test fails.

 2003 Prentice Hall, Inc. All rights reserved. Outline 52 fig15_12.cpp output (1 of 1) The following items were extracted from the istringstream object: string: Input string: test int: 123 double: 4.7 char: A inputString is empty