home *** CD-ROM | disk | FTP | other *** search
/ PC Format (South-Africa) 2001 May / PCFMay2001.iso / Xenon / C++ / FreeCommandLineTools.exe / Examples / StdLib / graph.cpp < prev    next >
Encoding:
C/C++ Source or Header  |  2000-01-31  |  5.2 KB  |  160 lines

  1. #include "stlexam.h"
  2. #pragma hdrstop
  3. /**************************************************************************
  4.  *
  5.  * graph.cpp - Graph program.  Section 9.3.2
  6.  *
  7.  ***************************************************************************
  8.  *
  9.  * (c) Copyright 1994, 1998 Rogue Wave Software, Inc.
  10.  * ALL RIGHTS RESERVED
  11.  *
  12.  * The software and information contained herein are proprietary to, and
  13.  * comprise valuable trade secrets of, Rogue Wave Software, Inc., which
  14.  * intends to preserve as trade secrets such software and information.
  15.  * This software is furnished pursuant to a written license agreement and
  16.  * may be used, copied, transmitted, and stored only in accordance with
  17.  * the terms of such license and with the inclusion of the above copyright
  18.  * notice.  This software and information or any other copies thereof may
  19.  * not be provided or otherwise made available to any other person.
  20.  *
  21.  * Notwithstanding any other lease or license that may pertain to, or
  22.  * accompany the delivery of, this computer software and information, the
  23.  * rights of the Government regarding its use, reproduction and disclosure
  24.  * are as set forth in Section 52.227-19 of the FARS Computer
  25.  * Software-Restricted Rights clause.
  26.  *
  27.  * Use, duplication, or disclosure by the Government is subject to
  28.  * restrictions as set forth in subparagraph (c)(1)(ii) of the Rights in
  29.  * Technical Data and Computer Software clause at DFARS 252.227-7013.
  30.  * Contractor/Manufacturer is Rogue Wave Software, Inc.,
  31.  * P.O. Box 2328, Corvallis, Oregon 97339.
  32.  *
  33.  * This computer software and information is distributed with "restricted
  34.  * rights."  Use, duplication or disclosure is subject to restrictions as
  35.  * set forth in NASA FAR SUP 18-52.227-79 (April 1985) "Commercial
  36.  * Computer Software-Restricted Rights (April 1985)."  If the Clause at
  37.  * 18-52.227-74 "Rights in Data General" is specified in the contract,
  38.  * then the "Alternate III" clause applies.
  39.  *
  40.  **************************************************************************/
  41.  
  42. #include <map>
  43. #include <vector>
  44. #include <queue>
  45.  
  46. #ifdef _RW_STD_IOSTREAM
  47. #include <iostream>
  48. #else
  49. #include <iostream.h>
  50. #endif
  51.  
  52. #include <string>
  53. #ifndef _RWSTD_NO_NAMESPACE
  54. using namespace std;
  55. #ifndef __BORLANDC__
  56. using namespace std::rel_ops;  // RW_BUG
  57. #endif
  58. #endif
  59.  
  60. typedef map<string, int, less<string>,allocator<string>  >          stringVector;
  61. typedef map<string, stringVector, less<string>,allocator<string>  > graph;
  62.  
  63. struct DistancePair
  64. {
  65.     unsigned first;
  66.     string   second;
  67.     DistancePair() : first(0) {}
  68.     DistancePair(unsigned f, const string& s) : first(f), second(s) {}
  69. };
  70.  
  71. bool operator< (const DistancePair& lhs, const DistancePair& rhs)
  72. {
  73.     return lhs.first < rhs.first;
  74. }
  75.  
  76. bool operator> (const DistancePair& lhs, const DistancePair& rhs)
  77. {
  78.     return lhs.first > rhs.first;
  79. }
  80.  
  81. string pendleton("Pendleton");
  82. string pensacola("Pensacola");
  83. string peoria("Peoria");
  84. string phoenix("Phoenix");
  85. string pierre("Pierre");
  86. string pittsburgh("Pittsburgh");
  87. string princeton("Princeton");
  88. string pueblo("Pueblo");
  89.  
  90. graph cityMap;
  91.  
  92. void shortestDistance (graph& cityMap, string& start, stringVector& distances)
  93. {
  94.     //
  95.     // Process a priority queue of distances to nodes.
  96.     //
  97.     priority_queue<DistancePair, vector<DistancePair,allocator<DistancePair> >,
  98.         greater<DistancePair> > que;
  99.     que.push(DistancePair(0, start));
  100.     
  101.     while (! que.empty())
  102.     {
  103.         //
  104.         // Pull nearest city from queue.
  105.         //
  106.         int distance = que.top().first;
  107.         string city = que.top().second;
  108.         que.pop();
  109.         //
  110.         // If we haven't seen it already, process it.
  111.         //
  112.         if (0 == distances.count(city))
  113.         {
  114.             //
  115.             // Then add it to shortest distance map.
  116.             //
  117.             distances[city] = distance;
  118.             //
  119.             // And put values into queue.
  120.             //
  121.             const stringVector& cities = cityMap[city];
  122.             stringVector::const_iterator start = cities.begin();
  123.             stringVector::const_iterator stop  = cities.end();
  124.             for (; start != stop; ++start)
  125.                 que.push(DistancePair(distance + (*start).second,
  126.                                       (*start).first));
  127.         }
  128.     }
  129. }
  130.  
  131. int main ()
  132. {
  133.     cout << "Graph example program, from Chapter 7" << endl;
  134.  
  135.     cityMap[pendleton][phoenix]    = 4;
  136.     cityMap[pendleton][pueblo]     = 8;
  137.     cityMap[pensacola][phoenix]    = 5;
  138.     cityMap[peoria][pittsburgh]    = 5;
  139.     cityMap[peoria][pueblo]        = 3;
  140.     cityMap[phoenix][peoria]       = 4;
  141.     cityMap[phoenix][pittsburgh]   = 10;
  142.     cityMap[phoenix][pueblo]       = 3;
  143.     cityMap[pierre][pendleton]     = 2;
  144.     cityMap[pittsburgh][pensacola] = 4;
  145.     cityMap[princeton][pittsburgh] = 2;
  146.     cityMap[pueblo][pierre]        = 3;
  147.     
  148.     stringVector distances;
  149.     
  150.     shortestDistance(cityMap, pierre, distances);
  151.     stringVector::iterator where;
  152.     for (where = distances.begin(); where != distances.end(); ++where)
  153.         cout << "Distance to: " << (*where).first << ":"
  154.              <<  (*where).second << endl;
  155.         
  156.     cout << "End of graph example program" << endl;
  157.  
  158.     return 0;
  159. }
  160.