-
Notifications
You must be signed in to change notification settings - Fork 14
Expand file tree
/
Copy pathstringiter2.cpp
More file actions
45 lines (39 loc) · 1.38 KB
/
stringiter2.cpp
File metadata and controls
45 lines (39 loc) · 1.38 KB
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
/* The following code example is taken from the book
* "The C++ Standard Library - A Tutorial and Reference, 2nd Edition"
* by Nicolai M. Josuttis, Addison-Wesley, 2012
*
* (C) Copyright Nicolai M. Josuttis 2012.
* Permission to copy, use, modify, sell and distribute this software
* is granted provided this copyright notice appears in all copies.
* This software is provided "as is" without express or implied
* warranty, and with no claim as to its suitability for any purpose.
*/
#include <string>
#include <iostream>
#include <algorithm>
using namespace std;
int main()
{
// create constant string
const string hello("Hello, how are you?");
// initialize string s with all characters of string hello
string s(hello.cbegin(),hello.cend());
// ranged-based for loop that iterates through all the characters
for (char c : s) {
cout << c;
}
cout << endl;
// reverse the order of all characters inside the string
reverse (s.begin(), s.end());
cout << "reverse: " << s << endl;
// sort all characters inside the string
sort (s.begin(), s.end());
cout << "ordered: " << s << endl;
// remove adjacent duplicates
// - unique() reorders and returns new end
// - erase() shrinks accordingly
s.erase (unique(s.begin(),
s.end()),
s.end());
cout << "no duplicates: " << s << endl;
}