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
|
#include <algorithm>
#include <string>
#include <cstring>
#include <iostream>
using namespace std;
class CaseString
{
public:
bool operator()(string const &first,
string const &second) const
{
return !strcasecmp(first.c_str(), second.c_str());
}
};
int main()
{
string first[] =
{
"Alpha", "bravo", "Charley", "delta", "Echo",
"foxtrot", "Golf", "hotel"
};
string second[] =
{
"alpha", "bravo", "charley", "delta", "echo",
"foxtrot", "golf", "hotel"
};
string *last = first + sizeof(first) / sizeof(string);
cout << "The elements of `first' and `second' are pairwise " <<
(equal(first, last, second) ? "equal" : "not equal") <<
'\n' <<
"compared case-insensitively, they are " <<
(
equal(first, last, second, CaseString{}) ?
"equal" : "not equal"
) << '\n';
}
/*
Displays:
The elements of `first' and `second' are pairwise not equal
compared case-insensitively, they are equal
*/
|