A<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.cppe.ru/index.php?action=history&amp;feed=atom&amp;title=C%2B%2B%2FData_Structure%2FMap</id>
		<title>C++/Data Structure/Map - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.cppe.ru/index.php?action=history&amp;feed=atom&amp;title=C%2B%2B%2FData_Structure%2FMap"/>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C%2B%2B/Data_Structure/Map&amp;action=history"/>
		<updated>2026-04-18T17:02:30Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.cppe.ru/index.php?title=C%2B%2B/Data_Structure/Map&amp;diff=932&amp;oldid=prev</id>
		<title> в 14:21, 25 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C%2B%2B/Data_Structure/Map&amp;diff=932&amp;oldid=prev"/>
				<updated>2010-05-25T14:21:06Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 14:21, 25 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.cppe.ru/index.php?title=C%2B%2B/Data_Structure/Map&amp;diff=933&amp;oldid=prev</id>
		<title>Admin: 1 версия:&amp;#32;Импорт контента...</title>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C%2B%2B/Data_Structure/Map&amp;diff=933&amp;oldid=prev"/>
				<updated>2010-05-25T10:24:14Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия: Импорт контента...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==A map: insert pair, find, end==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  map&amp;lt;char, int&amp;gt; mapObject;&lt;br /&gt;
  int i;&lt;br /&gt;
  for(i = 0; i &amp;lt;10; i++) {&lt;br /&gt;
    mapObject.insert(pair&amp;lt;char, int&amp;gt;(&amp;quot;A&amp;quot;+i, i));&lt;br /&gt;
  }&lt;br /&gt;
  char ch;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Enter key: &amp;quot;;&lt;br /&gt;
  cin &amp;gt;&amp;gt; ch;&lt;br /&gt;
  map&amp;lt;char, int&amp;gt;::iterator p;&lt;br /&gt;
  &lt;br /&gt;
  p = mapObject.find(ch);&lt;br /&gt;
  if(p != mapObject.end()) &lt;br /&gt;
    cout &amp;lt;&amp;lt; p-&amp;gt;second;&lt;br /&gt;
  else&lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Key not in map.\n&amp;quot;;&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==A map of opposites.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;cstring&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
class StringClass {&lt;br /&gt;
  char str[20];&lt;br /&gt;
public:&lt;br /&gt;
  StringClass() { &lt;br /&gt;
     strcpy(str, &amp;quot;&amp;quot;); &lt;br /&gt;
  }&lt;br /&gt;
  StringClass(char *s) { &lt;br /&gt;
     strcpy(str, s); &lt;br /&gt;
  }&lt;br /&gt;
  char *get() { &lt;br /&gt;
     return str; &lt;br /&gt;
  }&lt;br /&gt;
};&lt;br /&gt;
// must define less than relative to StringClass objects&lt;br /&gt;
bool operator&amp;lt;(StringClass a, StringClass b)&lt;br /&gt;
{&lt;br /&gt;
   return strcmp(a.get(), b.get()) &amp;lt; 0;&lt;br /&gt;
}&lt;br /&gt;
class opposite {&lt;br /&gt;
  char str[20];&lt;br /&gt;
public:&lt;br /&gt;
  opposite() { &lt;br /&gt;
     strcmp(str, &amp;quot;&amp;quot;); &lt;br /&gt;
  }&lt;br /&gt;
  opposite(char *s) { &lt;br /&gt;
     strcpy(str, s); &lt;br /&gt;
  }&lt;br /&gt;
  char *get() { &lt;br /&gt;
     return str; &lt;br /&gt;
  }&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  map&amp;lt;StringClass, opposite&amp;gt; mapObject;&lt;br /&gt;
  mapObject.insert(pair&amp;lt;StringClass, opposite&amp;gt;(StringClass(&amp;quot;yes&amp;quot;), opposite(&amp;quot;no&amp;quot;)));&lt;br /&gt;
  mapObject.insert(pair&amp;lt;StringClass, opposite&amp;gt;(StringClass(&amp;quot;good&amp;quot;), opposite(&amp;quot;bad&amp;quot;)));&lt;br /&gt;
  mapObject.insert(pair&amp;lt;StringClass, opposite&amp;gt;(StringClass(&amp;quot;left&amp;quot;), opposite(&amp;quot;right&amp;quot;)));&lt;br /&gt;
  mapObject.insert(pair&amp;lt;StringClass, opposite&amp;gt;(StringClass(&amp;quot;up&amp;quot;), opposite(&amp;quot;down&amp;quot;)));&lt;br /&gt;
  char str[80];&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Enter word: &amp;quot;;&lt;br /&gt;
  cin &amp;gt;&amp;gt; str;&lt;br /&gt;
  map&amp;lt;StringClass, opposite&amp;gt;::iterator p;&lt;br /&gt;
  &lt;br /&gt;
  p = mapObject.find(StringClass(str));&lt;br /&gt;
  if(p != mapObject.end()) &lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Opposite: &amp;quot; &amp;lt;&amp;lt;  p-&amp;gt;second.get();&lt;br /&gt;
  else&lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Word not in map.\n&amp;quot;;&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==A map of word opposites, using strings.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  map&amp;lt;string, string&amp;gt; mapObject;&lt;br /&gt;
  int i;&lt;br /&gt;
  mapObject.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;yes&amp;quot;, &amp;quot;no&amp;quot;));&lt;br /&gt;
  mapObject.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;up&amp;quot;, &amp;quot;down&amp;quot;));&lt;br /&gt;
  mapObject.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;left&amp;quot;, &amp;quot;right&amp;quot;));&lt;br /&gt;
  mapObject.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;good&amp;quot;, &amp;quot;bad&amp;quot;));&lt;br /&gt;
  string s;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Enter word: &amp;quot;;&lt;br /&gt;
  cin &amp;gt;&amp;gt; s;&lt;br /&gt;
  map&amp;lt;string, string&amp;gt;::iterator p;&lt;br /&gt;
  &lt;br /&gt;
  p = mapObject.find(s);&lt;br /&gt;
  if(p != mapObject.end()) &lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Opposite: &amp;quot; &amp;lt;&amp;lt; p-&amp;gt;second;&lt;br /&gt;
  else&lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Word not in map.\n&amp;quot;;&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==A simple map: char and int==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  map&amp;lt;char, int&amp;gt; mapObject;&lt;br /&gt;
  int i;&lt;br /&gt;
  for(i = 0; i &amp;lt;26; i++) {&lt;br /&gt;
    mapObject.insert(pair&amp;lt;char, int&amp;gt;(&amp;quot;A&amp;quot;+i, 65+i));&lt;br /&gt;
  }&lt;br /&gt;
  char ch;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Enter key: &amp;quot;;&lt;br /&gt;
  cin &amp;gt;&amp;gt; ch;&lt;br /&gt;
  map&amp;lt;char, int&amp;gt;::iterator p;&lt;br /&gt;
  &lt;br /&gt;
  p = mapObject.find(ch);&lt;br /&gt;
  if(p != mapObject.end()) &lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Its ASCII value is  &amp;quot; &amp;lt;&amp;lt; p-&amp;gt;second;&lt;br /&gt;
  else&lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Key not in map.\n&amp;quot;;&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==[] automatically inserts elements.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  map&amp;lt;char, int&amp;gt; mapObject;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Initial size of map: &amp;quot; &amp;lt;&amp;lt; mapObject.size() &amp;lt;&amp;lt; endl;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;The value associated with A is &amp;quot; &amp;lt;&amp;lt; mapObject[&amp;quot;A&amp;quot;];&lt;br /&gt;
  cout &amp;lt;&amp;lt; endl;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Size of map is now: &amp;quot; &amp;lt;&amp;lt; mapObject.size() &amp;lt;&amp;lt; endl;&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Cycle through a map in reverse.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  map&amp;lt;char, int&amp;gt; mapObject;&lt;br /&gt;
  int i;&lt;br /&gt;
  for(i = 0; i &amp;lt;26; i++)&lt;br /&gt;
    mapObject.insert(pair&amp;lt;char, int&amp;gt;(&amp;quot;A&amp;quot; + i, 65 + i));&lt;br /&gt;
  map&amp;lt;char, int&amp;gt;::reverse_iterator p;&lt;br /&gt;
  &lt;br /&gt;
  for(p = mapObject.rbegin(); p != mapObject.rend(); p++) {&lt;br /&gt;
    cout &amp;lt;&amp;lt; p-&amp;gt;first &amp;lt;&amp;lt; &amp;quot; has ASCII value of &amp;quot;;&lt;br /&gt;
    cout &amp;lt;&amp;lt; p-&amp;gt;second &amp;lt;&amp;lt; endl;&lt;br /&gt;
  }&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Cycle through a map using an iterator.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  map&amp;lt;char, int&amp;gt; mapObject;&lt;br /&gt;
  int i;&lt;br /&gt;
  for(i = 0; i &amp;lt; 26; i++)&lt;br /&gt;
    mapObject.insert(pair&amp;lt;char, int&amp;gt;(&amp;quot;A&amp;quot; + i, 65 + i));&lt;br /&gt;
  map&amp;lt;char, int&amp;gt;::iterator p;&lt;br /&gt;
  &lt;br /&gt;
  for(p = mapObject.begin(); p != mapObject.end(); p++) {&lt;br /&gt;
    cout &amp;lt;&amp;lt; p-&amp;gt;first &amp;lt;&amp;lt; &amp;quot; has ASCII value of &amp;quot;;&lt;br /&gt;
    cout &amp;lt;&amp;lt; p-&amp;gt;second &amp;lt;&amp;lt; endl;&lt;br /&gt;
  }&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Demonstrating a multimap.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  multimap&amp;lt;string, string&amp;gt; names;&lt;br /&gt;
  string n;&lt;br /&gt;
  names.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;Z&amp;quot;, &amp;quot;F&amp;quot;));&lt;br /&gt;
  names.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;Z&amp;quot;, &amp;quot;A&amp;quot;));&lt;br /&gt;
  names.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;S&amp;quot;, &amp;quot;T&amp;quot;));&lt;br /&gt;
  names.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;S&amp;quot;, &amp;quot;A&amp;quot;));&lt;br /&gt;
  names.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;S&amp;quot;, &amp;quot;J&amp;quot;));&lt;br /&gt;
  names.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;D&amp;quot;, &amp;quot;H&amp;quot;));&lt;br /&gt;
  names.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;D&amp;quot;, &amp;quot;W&amp;quot;));&lt;br /&gt;
  names.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;D&amp;quot;, &amp;quot;R&amp;quot;));&lt;br /&gt;
  multimap&amp;lt;string, string&amp;gt;::iterator p;&lt;br /&gt;
  &lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Enter last name: &amp;quot;;&lt;br /&gt;
  cin &amp;gt;&amp;gt; n;&lt;br /&gt;
  p = names.find(n);&lt;br /&gt;
  if(p != names.end()) { // found a name&lt;br /&gt;
    do {&lt;br /&gt;
      cout &amp;lt;&amp;lt; n &amp;lt;&amp;lt; &amp;quot;, &amp;quot; &amp;lt;&amp;lt; p-&amp;gt;second;&lt;br /&gt;
      cout &amp;lt;&amp;lt; endl;&lt;br /&gt;
      p++;&lt;br /&gt;
    } while (p != names.upper_bound(n));&lt;br /&gt;
  }&lt;br /&gt;
  else{&lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Name not found.\n&amp;quot;;&lt;br /&gt;
  }&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==File and map==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;                                                              &lt;br /&gt;
#include &amp;lt;fstream&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
    map&amp;lt;string, int&amp;gt; hist;                                                  &lt;br /&gt;
    ifstream in( &amp;quot;inFile&amp;quot; );                                                &lt;br /&gt;
    string word;&lt;br /&gt;
    while ( in &amp;gt;&amp;gt; word )                                                    &lt;br /&gt;
    hist[ word ]++;                                                         &lt;br /&gt;
    in.close();                                                             &lt;br /&gt;
    typedef map&amp;lt;string, int&amp;gt;::const_iterator CI;                            &lt;br /&gt;
    for ( CI iter = hist.begin(); iter != hist.end(); ++iter )              &lt;br /&gt;
        cout &amp;lt;&amp;lt; iter-&amp;gt;first &amp;lt;&amp;lt; &amp;quot;\t&amp;quot; &amp;lt;&amp;lt; iter-&amp;gt;second &amp;lt;&amp;lt; endl;                &lt;br /&gt;
    return 0;&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Maps can store only unique keys.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  map&amp;lt;char, int&amp;gt; mapObject;&lt;br /&gt;
  pair&amp;lt;map&amp;lt;char,int&amp;gt;::iterator, bool&amp;gt; res;&lt;br /&gt;
  res = mapObject.insert(pair&amp;lt;char, int&amp;gt;(&amp;quot;A&amp;quot;, 65));&lt;br /&gt;
  if(res.second) &lt;br /&gt;
     cout &amp;lt;&amp;lt; &amp;quot;Insertion occured.\n&amp;quot;;&lt;br /&gt;
  res = mapObject.insert(pair&amp;lt;char, int&amp;gt;(&amp;quot;A&amp;quot;, 99));&lt;br /&gt;
  if(!res.second) &lt;br /&gt;
     cout &amp;lt;&amp;lt; &amp;quot;Duplicate not allowed.\n&amp;quot;;&lt;br /&gt;
  map&amp;lt;char, int&amp;gt;::iterator p;&lt;br /&gt;
  &lt;br /&gt;
  p = mapObject.find(&amp;quot;A&amp;quot;);&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Its ASCII value is &amp;quot; &amp;lt;&amp;lt; p-&amp;gt;second;&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use a map of strings to create a phone directory.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  map&amp;lt;string, string&amp;gt; directory;&lt;br /&gt;
  directory.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;T&amp;quot;, &amp;quot;4444&amp;quot;));&lt;br /&gt;
  directory.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;C&amp;quot;, &amp;quot;9999&amp;quot;));&lt;br /&gt;
  directory.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;J&amp;quot;, &amp;quot;8888&amp;quot;));&lt;br /&gt;
  directory.insert(pair&amp;lt;string, string&amp;gt;(&amp;quot;R&amp;quot;, &amp;quot;0000&amp;quot;));&lt;br /&gt;
  string s;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Enter name: &amp;quot;;&lt;br /&gt;
  cin &amp;gt;&amp;gt; s;&lt;br /&gt;
  map&amp;lt;string, string&amp;gt;::iterator p;&lt;br /&gt;
  &lt;br /&gt;
  p = directory.find(s);&lt;br /&gt;
  if(p != directory.end()) &lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Phone number: &amp;quot; &amp;lt;&amp;lt; p-&amp;gt;second;&lt;br /&gt;
  else&lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Name not in directory.\n&amp;quot;;&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use a map to create a phone directory: string class==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
class name {&lt;br /&gt;
  string str;&lt;br /&gt;
public:&lt;br /&gt;
  name() { &lt;br /&gt;
      str = &amp;quot;&amp;quot;; &lt;br /&gt;
  }&lt;br /&gt;
  name(string s) { &lt;br /&gt;
      str = s; &lt;br /&gt;
  }&lt;br /&gt;
  string get() { &lt;br /&gt;
      return str; &lt;br /&gt;
  }&lt;br /&gt;
};&lt;br /&gt;
// Define less than relative to name objects.&lt;br /&gt;
bool operator&amp;lt;(name a, name b){&lt;br /&gt;
   return a.get() &amp;lt; b.get();&lt;br /&gt;
}&lt;br /&gt;
class phoneNum {&lt;br /&gt;
  string str;&lt;br /&gt;
public:&lt;br /&gt;
  phoneNum() { &lt;br /&gt;
      str = &amp;quot;&amp;quot;; &lt;br /&gt;
  }&lt;br /&gt;
  phoneNum(string s) { &lt;br /&gt;
      str = s; &lt;br /&gt;
  }&lt;br /&gt;
  string get() { &lt;br /&gt;
      return str; &lt;br /&gt;
  }&lt;br /&gt;
};&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  map&amp;lt;name, phoneNum&amp;gt; directory;&lt;br /&gt;
  directory.insert(pair&amp;lt;name, phoneNum&amp;gt;(name(&amp;quot;J&amp;quot;), phoneNum(&amp;quot;999-1111&amp;quot;)));&lt;br /&gt;
  directory.insert(pair&amp;lt;name, phoneNum&amp;gt;(name(&amp;quot;C&amp;quot;), phoneNum(&amp;quot;999-2222&amp;quot;)));&lt;br /&gt;
  directory.insert(pair&amp;lt;name, phoneNum&amp;gt;(name(&amp;quot;J&amp;quot;),  phoneNum(&amp;quot;555-3333&amp;quot;)));&lt;br /&gt;
  directory.insert(pair&amp;lt;name, phoneNum&amp;gt;(name(&amp;quot;T&amp;quot;),phoneNum(&amp;quot;4444&amp;quot;)));&lt;br /&gt;
  // given a name, find number&lt;br /&gt;
  string str;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Enter name: &amp;quot;;&lt;br /&gt;
  cin &amp;gt;&amp;gt; str;&lt;br /&gt;
  map&amp;lt;name, phoneNum&amp;gt;::iterator p;&lt;br /&gt;
  &lt;br /&gt;
  p = directory.find(name(str));&lt;br /&gt;
  if(p != directory.end()) &lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Phone number: &amp;quot; &amp;lt;&amp;lt;  p-&amp;gt;second.get();&lt;br /&gt;
  else&lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Name not in directory.\n&amp;quot;;&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use a multimap to create the phone directory.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
class name {&lt;br /&gt;
  string str;&lt;br /&gt;
public:&lt;br /&gt;
  name() { &lt;br /&gt;
     str = &amp;quot;&amp;quot;; &lt;br /&gt;
  }&lt;br /&gt;
  name(string s) { &lt;br /&gt;
     str = s; &lt;br /&gt;
  }&lt;br /&gt;
  string get() { &lt;br /&gt;
     return str; &lt;br /&gt;
  }&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
bool operator&amp;lt;(name a, name b) { // Define less than relative to name objects.&lt;br /&gt;
   return a.get() &amp;lt; b.get();&lt;br /&gt;
}&lt;br /&gt;
class phoneNum {&lt;br /&gt;
  string str;&lt;br /&gt;
public:&lt;br /&gt;
  phoneNum() { &lt;br /&gt;
     str = &amp;quot;&amp;quot;; &lt;br /&gt;
  }&lt;br /&gt;
  phoneNum(string s) { &lt;br /&gt;
     str = s; &lt;br /&gt;
  }&lt;br /&gt;
  string get() { &lt;br /&gt;
     return str; &lt;br /&gt;
  }&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  multimap&amp;lt;name, phoneNum&amp;gt; directory;&lt;br /&gt;
  directory.insert(pair&amp;lt;name, phoneNum&amp;gt;(name(&amp;quot;T&amp;quot;),    phoneNum(&amp;quot;555-4533&amp;quot;)));&lt;br /&gt;
  directory.insert(pair&amp;lt;name, phoneNum&amp;gt;(name(&amp;quot;T&amp;quot;),    phoneNum(&amp;quot;555-9999&amp;quot;)));&lt;br /&gt;
  directory.insert(pair&amp;lt;name, phoneNum&amp;gt;(name(&amp;quot;C&amp;quot;),  phoneNum(&amp;quot;555-9678&amp;quot;)));&lt;br /&gt;
  string str;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Enter name: &amp;quot;;&lt;br /&gt;
  cin &amp;gt;&amp;gt; str;&lt;br /&gt;
  multimap&amp;lt;name, phoneNum&amp;gt;::iterator p;&lt;br /&gt;
  &lt;br /&gt;
  p = directory.find(str);&lt;br /&gt;
  if(p != directory.end()) {&lt;br /&gt;
    do {&lt;br /&gt;
      cout &amp;lt;&amp;lt; &amp;quot;Phone number: &amp;quot; &amp;lt;&amp;lt;  p-&amp;gt;second.get();&lt;br /&gt;
      cout &amp;lt;&amp;lt; endl;&lt;br /&gt;
      p++;    &lt;br /&gt;
    } while(p != directory.upper_bound(str));&lt;br /&gt;
  }&lt;br /&gt;
  else&lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;Name not in directory.\n&amp;quot;;&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use the greater function object in Map==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  map&amp;lt;string, int, greater&amp;lt;string&amp;gt; &amp;gt; mapObject;&lt;br /&gt;
  mapObject[&amp;quot;A&amp;quot;] = 20;&lt;br /&gt;
  mapObject[&amp;quot;B&amp;quot;] = 19;&lt;br /&gt;
  mapObject[&amp;quot;C&amp;quot;] = 10;&lt;br /&gt;
  map&amp;lt;string, int, greater&amp;lt;string&amp;gt; &amp;gt;::iterator p;&lt;br /&gt;
  &lt;br /&gt;
  for(p = mapObject.begin(); p != mapObject.end(); p++) {&lt;br /&gt;
    cout &amp;lt;&amp;lt; p-&amp;gt;first &amp;lt;&amp;lt; &amp;quot; has value of &amp;quot;;&lt;br /&gt;
    cout &amp;lt;&amp;lt; p-&amp;gt;second &amp;lt;&amp;lt; endl;&lt;br /&gt;
  }&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Using [] in Map==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  map&amp;lt;char, int&amp;gt; mapObject;&lt;br /&gt;
  int i;&lt;br /&gt;
  for(i = 0; i &amp;lt; 26; i++)&lt;br /&gt;
    mapObject.insert(pair&amp;lt;char, int&amp;gt;(&amp;quot;A&amp;quot; + i, 65 + i));&lt;br /&gt;
  char ch;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Enter key: &amp;quot;;&lt;br /&gt;
  cin &amp;gt;&amp;gt; ch;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Its ASCII value is  &amp;quot; &amp;lt;&amp;lt; mapObject[ ch ];&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>