reverse_iterator_example.cpp 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. // (C) Copyright Jeremy Siek 2000-2004.
  2. // Distributed under the Boost Software License, Version 1.0. (See
  3. // accompanying file LICENSE_1_0.txt or copy at
  4. // http://www.boost.org/LICENSE_1_0.txt)
  5. #include <boost/config.hpp>
  6. #include <iostream>
  7. #include <algorithm>
  8. #include <boost/iterator/reverse_iterator.hpp>
  9. #include <boost/cstdlib.hpp>
  10. int main(int, char*[])
  11. {
  12. char letters_[] = "hello world!";
  13. const int N = sizeof(letters_)/sizeof(char) - 1;
  14. typedef char* base_iterator;
  15. base_iterator letters(letters_);
  16. std::cout << "original sequence of letters:\t\t\t"
  17. << letters_ << std::endl;
  18. // Use reverse_iterator to print a sequence of letters in reverse
  19. // order.
  20. boost::reverse_iterator<base_iterator>
  21. reverse_letters_first(letters + N),
  22. reverse_letters_last(letters);
  23. std::cout << "sequence in reverse order:\t\t\t";
  24. std::copy(reverse_letters_first, reverse_letters_last,
  25. std::ostream_iterator<char>(std::cout));
  26. std::cout << std::endl;
  27. std::cout << "sequence in double-reversed (normal) order:\t";
  28. std::copy(boost::make_reverse_iterator(reverse_letters_last),
  29. boost::make_reverse_iterator(reverse_letters_first),
  30. std::ostream_iterator<char>(std::cout));
  31. std::cout << std::endl;
  32. return boost::exit_success;
  33. }