querying.cpp
来自「Boost provides free peer-reviewed portab」· C++ 代码 · 共 271 行
CPP
271 行
/*============================================================================= Copyright (c) 2005 Dan Marsden Copyright (c) 2005-2007 Joel de Guzman Copyright (c) 2007 Hartmut Kaiser Distributed under the Boost Software License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)==============================================================================*/#include <boost/spirit/home/phoenix/stl/algorithm/querying.hpp>#include <boost/spirit/include/phoenix_core.hpp>#include <boost/detail/lightweight_test.hpp>#include <set>#include <functional>namespace{ struct even { bool operator()(const int i) const { return i % 2 == 0; } }; struct mod_2_comparison { bool operator()( const int lhs, const int rhs) { return lhs % 2 == rhs % 2; }; }; void find_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,2,3}; BOOST_TEST(find(arg1,2)(array) == array + 1); std::set<int> s(array, array + 3); BOOST_TEST(find(arg1, 2)(s) == s.find(2)); return; } void find_if_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,2,3}; BOOST_TEST(find_if(arg1, even())(array) == array + 1); return; } void find_end_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,2,3,1,2,3,1}; int pattern[] = {1,2,3}; BOOST_TEST(find_end(arg1, arg2)(array, pattern) == array + 3); int pattern2[] = {5,6,5}; BOOST_TEST(find_end(arg1, arg2, mod_2_comparison())(array, pattern2) == array + 3); return; } void find_first_of_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,2,3}; int search_for[] = {2,3,4}; BOOST_TEST(find_first_of(arg1, arg2)(array, search_for) == array + 1); int search_for2[] = {0}; BOOST_TEST(find_first_of(arg1, arg2, mod_2_comparison())(array, search_for2) == array + 1); return; } void adjacent_find_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {0,1,3,4,4}; BOOST_TEST(adjacent_find(arg1)(array) == array + 3); BOOST_TEST(adjacent_find(arg1, mod_2_comparison())(array) == array + 1); return; } void count_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,1,0,1,1}; BOOST_TEST(count(arg1, 1)(array) == 4); return; } void count_if_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,2,3,4,5}; BOOST_TEST(count_if(arg1, even())(array) == 2); return; } void distance_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,1,0,1,1}; BOOST_TEST(distance(arg1)(array) == 5); return; } void mismatch_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,2,3,4,5}; int search[] = {1,2,4}; BOOST_TEST( mismatch(arg1, arg2)(array, search) == std::make_pair(array + 2, search + 2)); int search2[] = {1,2,1,1}; BOOST_TEST( mismatch(arg1, arg2, mod_2_comparison())(array, search2) == std::make_pair(array + 3, search2 + 3)); return; } void equal_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,2,3}; int array2[] = {1,2,3}; int array3[] = {1,2,4}; BOOST_TEST( equal(arg1, arg2)(array, array2)); BOOST_TEST( !equal(arg1, arg2)(array, array3)); BOOST_TEST( equal(arg1, arg2, mod_2_comparison())(array, array2)); BOOST_TEST( !equal(arg1, arg2, mod_2_comparison())(array, array3)); return; } void search_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,2,3,1,2,3}; int pattern[] = {2,3}; BOOST_TEST( search(arg1, arg2)(array, pattern) == array + 1); int pattern2[] = {1,1}; BOOST_TEST( search(arg1, arg2, mod_2_comparison())(array, pattern2) == array + 2); return; } void lower_bound_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,2,3}; const std::set<int> test_set(array, array + 3); BOOST_TEST(lower_bound(arg1, 2)(array) == array + 1); BOOST_TEST(lower_bound(arg1, 2)(test_set) == test_set.lower_bound(2)); int array2[] = {3,2,1}; const std::set<int, std::greater<int> > test_set2(array2, array2 + 3); BOOST_TEST(boost::phoenix::lower_bound(arg1, 2, std::greater<int>())(array2) == array2 + 1); BOOST_TEST(boost::phoenix::lower_bound(arg1, 2, std::greater<int>())(test_set2) == test_set2.lower_bound(2)); return; } void upper_bound_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,2,3}; const std::set<int> test_set(array, array + 3); BOOST_TEST(upper_bound(arg1, 2)(array) == array + 2); BOOST_TEST(upper_bound(arg1, 2)(test_set) == test_set.upper_bound(2)); int array2[] = {3,2,1}; const std::set<int, std::greater<int> > test_set2(array2, array2 + 3); BOOST_TEST(boost::phoenix::upper_bound(arg1, 2, std::greater<int>())(array2) == array2 + 2); BOOST_TEST(boost::phoenix::upper_bound(arg1, 2, std::greater<int>())(test_set2) == test_set2.upper_bound(2)); return; } void equal_range_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,2,2,3}; const std::set<int> test_set(array, array + 4); BOOST_TEST(equal_range(arg1, 2)(array).first == array + 1); BOOST_TEST(equal_range(arg1, 2)(array).second == array + 3); BOOST_TEST(equal_range(arg1, 2)(test_set).first == test_set.equal_range(2).first); BOOST_TEST(equal_range(arg1, 2)(test_set).second == test_set.equal_range(2).second); int array2[] = {3,2,2,1}; const std::set<int, std::greater<int> > test_set2(array2, array2 + 4); BOOST_TEST(boost::phoenix::equal_range(arg1, 2, std::greater<int>())(array2).first == array2 + 1); BOOST_TEST(boost::phoenix::equal_range(arg1, 2, std::greater<int>())(array2).second == array2 + 3); BOOST_TEST(boost::phoenix::equal_range(arg1, 2, std::greater<int>())(test_set2).first == test_set2.equal_range(2).first); BOOST_TEST(boost::phoenix::equal_range(arg1, 2, std::greater<int>())(test_set2).second == test_set2.equal_range(2).second); return; } void binary_search_test() { using namespace boost::phoenix; using namespace boost::phoenix::arg_names; int array[] = {1,2,3}; BOOST_TEST(binary_search(arg1, 2)(array)); BOOST_TEST(!binary_search(arg1, 4)(array)); return; }}int main(){ find_test(); find_if_test(); find_end_test(); find_first_of_test(); adjacent_find_test(); count_test(); count_if_test(); distance_test(); mismatch_test(); equal_test(); search_test(); lower_bound_test(); upper_bound_test(); equal_range_test(); binary_search_test(); return boost::report_errors();}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?