mirror of
				https://github.com/boostorg/algorithm.git
				synced 2025-10-25 13:51:44 +02:00 
			
		
		
		
	
		
			
	
	
		
			95 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
		
		
			
		
	
	
			95 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
|   | /*
 | ||
|  |    Copyright (c) Alexander Zaitsev <zamazan4ik@gmail.by>, 2016 | ||
|  | 
 | ||
|  |    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)
 | ||
|  | 
 | ||
|  |     For more information, see http://www.boost.org
 | ||
|  | */ | ||
|  | 
 | ||
|  | #include <vector>
 | ||
|  | #include <list>
 | ||
|  | #include <iterator>
 | ||
|  | #include <functional>
 | ||
|  | #include <iostream>
 | ||
|  | 
 | ||
|  | #include <boost/algorithm/is_palindrome.hpp>
 | ||
|  | 
 | ||
|  | 
 | ||
|  | namespace ba = boost::algorithm; | ||
|  | 
 | ||
|  | template <typename T> | ||
|  | bool funcComparator(const T& v1, const T& v2) | ||
|  | { | ||
|  |     return v1 == v2; | ||
|  | } | ||
|  | 
 | ||
|  | struct functorComparator | ||
|  | { | ||
|  |     template <typename T> | ||
|  |     bool operator()(const T& v1, const T& v2) const | ||
|  |     { | ||
|  |         return v1 == v2; | ||
|  |     } | ||
|  | }; | ||
|  | 
 | ||
|  | 
 | ||
|  | int main ( int /*argc*/, char * /*argv*/ [] ) | ||
|  | { | ||
|  |     //You can this algorithm with iterators(minimum Bidirectional)
 | ||
|  |     std::vector<int> vec{1,2,1}; | ||
|  |     if(ba::is_palindrome(vec.begin(), vec.end())) | ||
|  |         std::cout << "This container is palindrome" << std::endl; | ||
|  |     else | ||
|  |         std::cout << "This container is not palindrome" << std::endl; | ||
|  | 
 | ||
|  | 
 | ||
|  |     //Of course, you can use const iterators
 | ||
|  |     if(ba::is_palindrome(vec.cbegin(), vec.cend())) | ||
|  |         std::cout << "This container is palindrome" << std::endl; | ||
|  |     else | ||
|  |         std::cout << "This container is not palindrome" << std::endl; | ||
|  | 
 | ||
|  | 
 | ||
|  |     //Example with bidirectional iterators
 | ||
|  |     std::list<int> list{1,2,1}; | ||
|  |     if(ba::is_palindrome(list.begin(), list.end())) | ||
|  |         std::cout << "This container is palindrome" << std::endl; | ||
|  |     else | ||
|  |         std::cout << "This container is not palindrome" << std::endl; | ||
|  | 
 | ||
|  | 
 | ||
|  |     //You can use custom comparators like functions, functors, lambdas
 | ||
|  |     auto lambdaComparator = [](int v1, int v2){ return v1 == v2; }; | ||
|  |     auto objFunc = std::function<bool(int, int)>(lambdaComparator); | ||
|  | 
 | ||
|  |     if(ba::is_palindrome(vec.begin(), vec.end(), lambdaComparator)) | ||
|  |         std::cout << "This container is palindrome" << std::endl; | ||
|  |     else | ||
|  |         std::cout << "This container is not palindrome" << std::endl; | ||
|  | 
 | ||
|  |     if(ba::is_palindrome(vec.begin(), vec.end(), funcComparator<int>)) | ||
|  |         std::cout << "This container is palindrome" << std::endl; | ||
|  |     else | ||
|  |         std::cout << "This container is not palindrome" << std::endl; | ||
|  | 
 | ||
|  |     if(ba::is_palindrome(vec.begin(), vec.end(), functorComparator())) | ||
|  |         std::cout << "This container is palindrome" << std::endl; | ||
|  |     else | ||
|  |         std::cout << "This container is not palindrome" << std::endl; | ||
|  | 
 | ||
|  |     if(ba::is_palindrome(vec.begin(), vec.end(), objFunc)) | ||
|  |         std::cout << "This container is palindrome" << std::endl; | ||
|  |     else | ||
|  |         std::cout << "This container is not palindrome" << std::endl; | ||
|  | 
 | ||
|  | 
 | ||
|  |     //You can use ranges
 | ||
|  |     if(ba::is_palindrome(vec)) | ||
|  |         std::cout << "This container is palindrome" << std::endl; | ||
|  |     else | ||
|  |         std::cout << "This container is not palindrome" << std::endl; | ||
|  | 
 | ||
|  |     return 0; | ||
|  | } |