]> git.ipfire.org Git - thirdparty/gcc.git/blob - libstdc++-v3/testsuite/26_numerics/adjacent_difference/1.cc
stl_numeric.h (iota): Add in C++0x mode.
[thirdparty/gcc.git] / libstdc++-v3 / testsuite / 26_numerics / adjacent_difference / 1.cc
1 // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
2 // Free Software Foundation, Inc.
3 //
4 // This file is part of the GNU ISO C++ Library. This library is free
5 // software; you can redistribute it and/or modify it under the
6 // terms of the GNU General Public License as published by the
7 // Free Software Foundation; either version 2, or (at your option)
8 // any later version.
9
10 // This library is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 // GNU General Public License for more details.
14
15 // You should have received a copy of the GNU General Public License along
16 // with this library; see the file COPYING. If not, write to the Free
17 // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
18 // USA.
19
20 // 26.4.4 [lib.adjacent.difference]
21
22 #include <algorithm>
23 #include <numeric>
24 #include <testsuite_hooks.h>
25
26 int A[] = {1, 4, 9, 16, 25, 36, 49, 64, 81, 100};
27 int B[] = {1, 3, 5, 7, 9, 11, 13, 15, 17, 19};
28 const int N = sizeof(A) / sizeof(int);
29
30 void
31 test01()
32 {
33 bool test __attribute__((unused)) = true;
34
35 int D[N];
36
37 std::adjacent_difference(A, A + N, D);
38 VERIFY( std::equal(D, D + N, B) );
39 }
40
41 int
42 main()
43 {
44 test01();
45 return 0;
46 }