2000-04-21 20:33:34 +00:00
|
|
|
// 1999-06-24 bkoz
|
|
|
|
|
|
|
|
// Copyright (C) 1999 Free Software Foundation, Inc.
|
|
|
|
//
|
|
|
|
// This file is part of the GNU ISO C++ Library. This library is free
|
|
|
|
// software; you can redistribute it and/or modify it under the
|
|
|
|
// terms of the GNU General Public License as published by the
|
|
|
|
// Free Software Foundation; either version 2, or (at your option)
|
|
|
|
// any later version.
|
|
|
|
|
|
|
|
// This library is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
|
|
|
|
// You should have received a copy of the GNU General Public License along
|
|
|
|
// with this library; see the file COPYING. If not, write to the Free
|
|
|
|
// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
|
|
|
|
// USA.
|
|
|
|
|
|
|
|
// 23.3.4 template class multiset
|
|
|
|
|
|
|
|
#include <iostream>
|
2001-06-26 21:22:57 +00:00
|
|
|
#include <iterator>
|
2000-04-21 20:33:34 +00:00
|
|
|
#include <set>
|
|
|
|
#include <algorithm>
|
|
|
|
|
2001-06-26 21:22:57 +00:00
|
|
|
namespace std
|
|
|
|
{
|
2000-04-21 20:33:34 +00:00
|
|
|
std::ostream&
|
|
|
|
operator<<(std::ostream& os, std::pair<int, int> const& p)
|
|
|
|
{ return os << p.first << ' ' << p.second; }
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
operator<(std::pair<int, int> const& lhs, std::pair<int, int> const& rhs)
|
|
|
|
{ return lhs.first < rhs.first; }
|
|
|
|
|
|
|
|
int main ()
|
|
|
|
{
|
|
|
|
typedef std::multiset<std::pair<int, int> >::iterator iterator;
|
|
|
|
std::pair<int, int> p(69, 0);
|
|
|
|
std::multiset<std::pair<int, int> > s;
|
|
|
|
|
|
|
|
for (p.second = 0; p.second < 5; ++p.second)
|
|
|
|
s.insert(p);
|
|
|
|
for (iterator it = s.begin(); it != s.end(); ++it)
|
|
|
|
if (it->second < 5)
|
|
|
|
{
|
|
|
|
s.insert(it, p);
|
|
|
|
++p.second;
|
|
|
|
}
|
|
|
|
|
|
|
|
// XXX need to use debug-assert here and get this working with an
|
|
|
|
// ostrinsrtream, that way we can just check the strings for
|
|
|
|
// equivalance.
|
|
|
|
std::copy(s.begin(), s.end(),
|
|
|
|
std::ostream_iterator<std::pair<int, int> >(std::cout, "\n"));
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* output:
|
|
|
|
69 5
|
|
|
|
69 0
|
|
|
|
69 6
|
|
|
|
69 1
|
|
|
|
69 7
|
|
|
|
69 2
|
|
|
|
69 8
|
|
|
|
69 3
|
|
|
|
69 9
|
|
|
|
69 4
|
|
|
|
*/
|