inplace_merge.pass.cpp 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. //===----------------------------------------------------------------------===//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is distributed under the University of Illinois Open Source
  6. // License. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. // <algorithm>
  10. // template<BidirectionalIterator Iter>
  11. // requires ShuffleIterator<Iter>
  12. // && LessThanComparable<Iter::value_type>
  13. // void
  14. // inplace_merge(Iter first, Iter middle, Iter last);
  15. #include <algorithm>
  16. #include <cassert>
  17. #include "../../iterators.h"
  18. template <class Iter>
  19. void
  20. test_one(unsigned N, unsigned M)
  21. {
  22. assert(M <= N);
  23. int* ia = new int[N];
  24. for (unsigned i = 0; i < N; ++i)
  25. ia[i] = i;
  26. std::random_shuffle(ia, ia+N);
  27. std::sort(ia, ia+M);
  28. std::sort(ia+M, ia+N);
  29. std::inplace_merge(Iter(ia), Iter(ia+M), Iter(ia+N));
  30. if(N > 0)
  31. {
  32. assert(ia[0] == 0);
  33. assert(ia[N-1] == N-1);
  34. assert(std::is_sorted(ia, ia+N));
  35. }
  36. delete [] ia;
  37. }
  38. template <class Iter>
  39. void
  40. test(unsigned N)
  41. {
  42. test_one<Iter>(N, 0);
  43. test_one<Iter>(N, N/4);
  44. test_one<Iter>(N, N/2);
  45. test_one<Iter>(N, 3*N/4);
  46. test_one<Iter>(N, N);
  47. }
  48. template <class Iter>
  49. void
  50. test()
  51. {
  52. test_one<Iter>(0, 0);
  53. test_one<Iter>(1, 0);
  54. test_one<Iter>(1, 1);
  55. test_one<Iter>(2, 0);
  56. test_one<Iter>(2, 1);
  57. test_one<Iter>(2, 2);
  58. test_one<Iter>(3, 0);
  59. test_one<Iter>(3, 1);
  60. test_one<Iter>(3, 2);
  61. test_one<Iter>(3, 3);
  62. test<Iter>(4);
  63. test<Iter>(100);
  64. test<Iter>(1000);
  65. }
  66. int main()
  67. {
  68. test<bidirectional_iterator<int*> >();
  69. test<random_access_iterator<int*> >();
  70. test<int*>();
  71. }