kyopro-lib

This documentation is automatically generated by online-judge-tools/verification-helper

View on GitHub

:question: Max monoid
(Mylib/AlgebraicStructure/Monoid/max.cpp)

Operations

Requirements

Notes

Problems

References

Verified with

Code

#pragma once
#include <algorithm>
#include <optional>

namespace haar_lib {
  template <typename T>
  struct max_monoid {
    using value_type = std::optional<T>;

    value_type operator()() const { return {}; }
    value_type operator()(const value_type &a, const value_type &b) const {
      if (not a) return b;
      if (not b) return a;
      return {std::max(*a, *b)};
    }
  };
}  // namespace haar_lib
#line 2 "Mylib/AlgebraicStructure/Monoid/max.cpp"
#include <algorithm>
#include <optional>

namespace haar_lib {
  template <typename T>
  struct max_monoid {
    using value_type = std::optional<T>;

    value_type operator()() const { return {}; }
    value_type operator()(const value_type &a, const value_type &b) const {
      if (not a) return b;
      if (not b) return a;
      return {std::max(*a, *b)};
    }
  };
}  // namespace haar_lib
Back to top page