File: is_palindrome_example.cpp

package info (click to toggle)
boost1.83 1.83.0-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 545,632 kB
  • sloc: cpp: 3,857,086; xml: 125,552; ansic: 34,414; python: 25,887; asm: 5,276; sh: 4,799; ada: 1,681; makefile: 1,629; perl: 1,212; pascal: 1,139; sql: 810; yacc: 478; ruby: 102; lisp: 24; csh: 6
file content (99 lines) | stat: -rw-r--r-- 3,039 bytes parent folder | download | duplicates (15)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/*
   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;
    
    //You can use C-strings
    if(ba::is_palindrome("aba"))
	std::cout << "This C-string is palindrome" << std::endl;
    else
        std::cout << "This C-string is not palindrome" << std::endl;
    return 0;
}