zoukankan      html  css  js  c++  java
  • C++函数式编程-Predicate

    在学习java的函数式编程思想后,发现这样的编程方式值得的学习,故用C++模拟实现一个简易的Predicate。欢迎大家指正。

    代码如下:

    template<typename T>
    class Predicate {
    	typedef std::function<bool(const T&)> PredicateType;
    
    public:
    	Predicate(const PredicateType& cur) :m_cur(cur) {
    		//std::cout << "PredicateType con : " << this << std::endl;
    	}
    
    	~Predicate() {
    		//std::cout << "des : " << this << std::endl;
    	}
    
    	Predicate Add(const PredicateType& other) const {
    		return Predicate([&](const T& a) {
    			return  m_cur(a) && other(a);
    		});
    	}
    
    	Predicate Or(const PredicateType& other) const {
    		return Predicate([&](const T& a) {
    			return m_cur(a) || other(a);
    		});
    	}
    
    	Predicate Negate()const {
    		return Predicate([&](const T& a) {
    			return !m_cur(a);
    		});
    	}
    
    	bool operator()(const T& a)const {
    		return  m_cur(a);
    	}
    
    private:
    	PredicateType m_cur;
    };
    

      

    测试代码如下:

    int main(int argc, char* argv[]) {
        Predicate<int> p([](int a) { return a > 5; });
        auto ret = p.Or([](int a) {return a < 1; })
            .Add([](int a) {return a > -1; })
            .Negate()
            (-1);
        std::cout << std::boolalpha << ret << std::endl;
        return 0;
    }

    输出结果如下:

  • 相关阅读:
    3.3 直方图处理与函数绘图
    光头强
    考试代码模板
    【2015初赛】预备
    NOIP2018 模拟题
    NOIP2017 模拟赛
    【解题报告】树形DP入门
    【解题报告】区间DP
    【解题报告】树形背包
    二分刷题单
  • 原文地址:https://www.cnblogs.com/sancong/p/14607207.html
Copyright © 2011-2022 走看看