This documentation is automatically generated by online-judge-tools/verification-helper
View the Project on GitHub ruthen71/rcpl
#include "algebra/monoid_s_f/monoid_min_set.hpp"
#pragma once #include "algebra/monoid_s/monoid_min.hpp" #include "algebra/monoid_f/monoid_set.hpp" // MSF template <class T> struct MonoidMinSet { using MS = MonoidMin<T>; using MF = MonoidSet<T>; using S = typename MS::S; using F = typename MF::F; static constexpr S mapping(F f, S x) { return f == MF::id() ? x : f; } };
#line 2 "algebra/monoid_s/monoid_min.hpp" // MS template <class T> struct MonoidMin { using S = T; static constexpr S op(S a, S b) { return std::min(a, b); } static constexpr S e() { return std::numeric_limits<T>::max(); } }; #line 2 "algebra/monoid_f/monoid_set.hpp" // MF template <class T> struct MonoidSet { using F = T; static constexpr F composition(F f, F g) { return f == id() ? g : f; } static constexpr F id() { return std::numeric_limits<F>::max(); } }; #line 4 "algebra/monoid_s_f/monoid_min_set.hpp" // MSF template <class T> struct MonoidMinSet { using MS = MonoidMin<T>; using MF = MonoidSet<T>; using S = typename MS::S; using F = typename MF::F; static constexpr S mapping(F f, S x) { return f == MF::id() ? x : f; } };