/* The following code example is taken from the book * "The C++ Standard Library - A Tutorial and Reference" * by Nicolai M. Josuttis, Addison-Wesley, 1999 * * (C) Copyright Nicolai M. Josuttis 1999. * 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 #include "algostuff.hpp" using namespace std; class MyRandom { public: ptrdiff_t operator() (ptrdiff_t max) { double tmp; tmp = static_cast(rand()) / static_cast(RAND_MAX); return static_cast(tmp * max); } }; int main() { vector coll; INSERT_ELEMENTS(coll,1,9); PRINT_ELEMENTS(coll,"coll: "); // shuffle all elements randomly random_shuffle (coll.begin(), coll.end()); PRINT_ELEMENTS(coll,"shuffled: "); // sort them again sort (coll.begin(), coll.end()); PRINT_ELEMENTS(coll,"sorted: "); /* shuffle elements with self-written random number generator * - to pass an lvalue we have to use a temporary object */ MyRandom rd; random_shuffle (coll.begin(), coll.end(), // range rd); // random number generator PRINT_ELEMENTS(coll,"shuffled: "); }