a01sa01to's competitive programming library. Requires C++20 or higher with GCC. This documentation is automatically generated by online-judge-tools/verification-helper
#include "library/_internal/graph-base.hpp"#pragma once
#include <concepts>
#include <cstddef>
#include <ranges>
#include <utility>
using namespace std;
namespace asalib::_internal {
// vector<vector<int>> とかの隣接リストを表す型
template<class T>
concept adjacency_list = requires(T t) {
{ t.size() } -> convertible_to<size_t>;
{ t[0] } -> ranges::range;
{ *ranges::begin(t[0]) } -> convertible_to<size_t>;
};
// 辺のリストを表す型
// 重み付きも考慮し pair<int, int> と tuple<int, int, int> の両方を許容
template<class T>
concept edge_list = requires(T t) {
{ t.size() } -> convertible_to<size_t>;
{ get<0>(t[0]) } -> convertible_to<size_t>;
{ get<1>(t[0]) } -> convertible_to<size_t>;
};
} // namespace asalib::_internal#line 2 "library/_internal/graph-base.hpp"
#include <concepts>
#include <cstddef>
#include <ranges>
#include <utility>
using namespace std;
namespace asalib::_internal {
// vector<vector<int>> とかの隣接リストを表す型
template<class T>
concept adjacency_list = requires(T t) {
{ t.size() } -> convertible_to<size_t>;
{ t[0] } -> ranges::range;
{ *ranges::begin(t[0]) } -> convertible_to<size_t>;
};
// 辺のリストを表す型
// 重み付きも考慮し pair<int, int> と tuple<int, int, int> の両方を許容
template<class T>
concept edge_list = requires(T t) {
{ t.size() } -> convertible_to<size_t>;
{ get<0>(t[0]) } -> convertible_to<size_t>;
{ get<1>(t[0]) } -> convertible_to<size_t>;
};
} // namespace asalib::_internal