結果
問題 | No.1207 グラフX |
ユーザー | RTnF |
提出日時 | 2020-08-30 14:03:24 |
言語 | C++17 (gcc 12.3.0 + boost 1.83.0) |
結果 |
AC
|
実行時間 | 297 ms / 2,000 ms |
コード長 | 7,434 bytes |
コンパイル時間 | 2,517 ms |
コンパイル使用メモリ | 213,832 KB |
実行使用メモリ | 71,932 KB |
最終ジャッジ日時 | 2024-11-15 07:16:35 |
合計ジャッジ時間 | 13,730 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 213 ms
54,112 KB |
testcase_01 | AC | 213 ms
54,164 KB |
testcase_02 | AC | 212 ms
54,144 KB |
testcase_03 | AC | 223 ms
54,096 KB |
testcase_04 | AC | 210 ms
54,080 KB |
testcase_05 | AC | 296 ms
71,796 KB |
testcase_06 | AC | 297 ms
71,716 KB |
testcase_07 | AC | 295 ms
71,884 KB |
testcase_08 | AC | 161 ms
46,568 KB |
testcase_09 | AC | 176 ms
50,908 KB |
testcase_10 | AC | 276 ms
64,728 KB |
testcase_11 | AC | 291 ms
71,932 KB |
testcase_12 | AC | 163 ms
47,572 KB |
testcase_13 | AC | 78 ms
37,972 KB |
testcase_14 | AC | 204 ms
53,240 KB |
testcase_15 | AC | 170 ms
49,272 KB |
testcase_16 | AC | 81 ms
38,996 KB |
testcase_17 | AC | 134 ms
45,412 KB |
testcase_18 | AC | 111 ms
45,516 KB |
testcase_19 | AC | 118 ms
41,868 KB |
testcase_20 | AC | 208 ms
53,976 KB |
testcase_21 | AC | 20 ms
35,028 KB |
testcase_22 | AC | 136 ms
45,584 KB |
testcase_23 | AC | 149 ms
47,448 KB |
testcase_24 | AC | 106 ms
44,296 KB |
testcase_25 | AC | 208 ms
53,888 KB |
testcase_26 | AC | 160 ms
48,604 KB |
testcase_27 | AC | 193 ms
51,632 KB |
testcase_28 | AC | 174 ms
50,628 KB |
testcase_29 | AC | 184 ms
51,652 KB |
testcase_30 | AC | 88 ms
41,152 KB |
testcase_31 | AC | 66 ms
36,820 KB |
testcase_32 | AC | 80 ms
41,668 KB |
testcase_33 | AC | 85 ms
41,448 KB |
testcase_34 | AC | 167 ms
48,940 KB |
testcase_35 | AC | 22 ms
35,024 KB |
testcase_36 | AC | 167 ms
50,220 KB |
testcase_37 | AC | 143 ms
46,444 KB |
testcase_38 | AC | 43 ms
37,524 KB |
testcase_39 | AC | 87 ms
42,332 KB |
testcase_40 | AC | 49 ms
35,156 KB |
testcase_41 | AC | 111 ms
42,024 KB |
testcase_42 | AC | 11 ms
34,776 KB |
testcase_43 | AC | 11 ms
34,768 KB |
testcase_44 | AC | 11 ms
34,768 KB |
testcase_45 | AC | 205 ms
54,272 KB |
testcase_46 | AC | 205 ms
54,652 KB |
testcase_47 | AC | 205 ms
54,472 KB |
testcase_48 | AC | 203 ms
54,056 KB |
ソースコード
#pragma region template #include <bits/stdc++.h> using namespace std; using ll = long long; using ull = unsigned long long; using ld = long double; using vi = vector<int>; using vvi = vector<vi>; using vvvi = vector<vvi>; using vll = vector<ll>; using vvll = vector<vll>; using vvvll = vector<vvll>; using vld = vector<ld>; using vvld = vector<vld>; using vvvld = vector<vvld>; using vs = vector<string>; using pll = pair<ll, ll>; using vp = vector<pll>; template <typename T> using pqrev = priority_queue<T, vector<T>, greater<T>>; #define rep(i, n) for (ll i = 0, i##_end = (n); i < i##_end; i++) #define repb(i, n) for (ll i = (n)-1; i >= 0; i--) #define repr(i, a, b) for (ll i = (a), i##_end = (b); i < i##_end; i++) #define reprb(i, a, b) for (ll i = (b)-1, i##_end = (a); i >= i##_end; i--) #define ALL(a) (a).begin(), (a).end() #define SZ(x) ((ll)(x).size()) //* constexpr ll MOD = 1e9 + 7; /*/ constexpr ll MOD = 998244353; //*/ constexpr ll INF = 1e+18; constexpr ld EPS = 1e-12L; constexpr ld PI = 3.14159265358979323846L; constexpr ll GCD(ll a, ll b) { return b ? GCD(b, a % b) : a; } constexpr ll LCM(ll a, ll b) { return a / GCD(a, b) * b; } template <typename S, typename T> constexpr bool chmax(S &a, const T &b) { if (a < b) { a = b; return 1; } return 0; } template <typename S, typename T> constexpr bool chmin(S &a, const T &b) { if (b < a) { a = b; return 1; } return 0; } #ifdef OJ_LOCAL #include "dump.hpp" #else #define dump(...) ((void)0) #endif template <typename T> bool print_(const T &a) { cout << a; return true; } template <typename T> bool print_(const vector<T> &vec) { for (auto &a : vec) { cout << a; if (&a != &vec.back()) { cout << " "; } } return false; } template <typename T> bool print_(const vector<vector<T>> &vv) { for (auto &v : vv) { for (auto &a : v) { cout << a; if (&a != &v.back()) { cout << " "; } } if (&v != &vv.back()) { cout << "\n"; } } return false; } void print() { cout << "\n"; } template <typename Head, typename... Tail> void print(Head &&head, Tail &&... tail) { bool f = print_(head); if (sizeof...(tail) != 0) { cout << (f ? " " : "\n"); } print(forward<Tail>(tail)...); } #pragma endregion // ModInt // 参考:https://ei1333.github.io/luzhiled/snippets/math/mod-int.html // modはコンパイル時に決定 template <ll mod> struct ModInt { ll x; ModInt() : x(0) {} ModInt(ll y) : x(y >= 0 ? y % mod : (mod - (-y) % mod) % mod) {} constexpr ModInt &operator+=(const ModInt &p) { if ((x += p.x) >= mod) x -= mod; return *this; } constexpr ModInt &operator-=(const ModInt &p) { if ((x += mod - p.x) >= mod) x -= mod; return *this; } constexpr ModInt &operator*=(const ModInt &p) { x = x * p.x % mod; return *this; } constexpr ModInt &operator/=(const ModInt &p) { *this *= p.inverse(); return *this; } constexpr ModInt operator-() { return ModInt(-x); } constexpr ModInt operator+(const ModInt &p) { return ModInt(*this) += p; } constexpr ModInt operator-(const ModInt &p) { return ModInt(*this) -= p; } constexpr ModInt operator*(const ModInt &p) { return ModInt(*this) *= p; } constexpr ModInt operator/(const ModInt &p) { return ModInt(*this) /= p; } constexpr bool operator==(const ModInt &p) { return x == p.x; } constexpr bool operator!=(const ModInt &p) { return x != p.x; } constexpr ModInt inverse() const { ll a = x, b = mod, u = 1, v = 0, t; while (b > 0) { t = a / b; swap(a -= t * b, b); swap(u -= t * v, v); } return ModInt(u); } constexpr ModInt pow(ll n) { ModInt ret(1), mul(x); while (n > 0) { if (n & 1) ret *= mul; mul *= mul; n >>= 1; } return ret; } friend ostream &operator<<(ostream &os, const ModInt &p) { return os << p.x; } friend istream &operator>>(istream &is, ModInt &a) { ll t; is >> t; a = ModInt<mod>(t); return (is); } }; using mint = ModInt<MOD>; using vm = vector<mint>; using vvm = vector<vm>; constexpr int MAX_FAC = 2000010; mint fac[MAX_FAC], facinv[MAX_FAC]; void combInit() { fac[0] = mint(1); for (int i = 0; i < MAX_FAC - 1; i++) { fac[i + 1] = fac[i] * (i + 1); } facinv[MAX_FAC - 1] = fac[MAX_FAC - 1].inverse(); for (int i = MAX_FAC - 2; i >= 0; i--) { facinv[i] = facinv[i + 1] * (i + 1); } } mint comb(const ll a, const ll b) { assert(a < MAX_FAC); assert(b < MAX_FAC); if (a < 0 || b < 0 || b > a) { return mint(0); } mint ret(1); ret *= fac[a]; ret *= facinv[b]; ret *= facinv[a - b]; return ret; } mint multicomb(const ll a, const ll b) { return comb(a + b - 1, b); } template <typename T> struct Edge { int from, to; T cost; int id; Edge(int from_, int to_, T cost_, int id_) : from(from_), to(to_), cost(cost_), id(id_) {} Edge(int from_, int to_, T cost_) : from(from_), to(to_), cost(cost_) {} Edge(int from_, int to_) : from(from_), to(to_), cost(1) {} bool operator<(const Edge<T> &r) { return cost < r.cost; } }; template <typename T> ostream &operator<<(ostream &os, Edge<T> edge) { os << edge.from << " -> " << edge.to << " (" << edge.cost << ")"; return os; } // グラフテンプレート(隣接リスト) template <typename E = Edge<ll>> struct GraphL { // 頂点数、辺数 int n, m; // 隣接リスト vector<vector<E>> adj; GraphL(int n_) : n(n_), m(0), adj(n_) {} template <typename... Args> void add_edge(int from, int to, Args... args) { adj[from].emplace_back(from, to, args...); m++; } vector<E> &operator[](int i) { return adj[i]; } }; template <typename E = Edge<ll>> ostream &operator<<(ostream &os, GraphL<E> graph) { os << "V = " << graph.n << ", E = " << graph.m << "\n"; for (const auto &ev : graph.adj) { for (const auto &e : ev) { os << e << "\n"; } } return os; } struct UnionFind { // 木の頂点数と高さは根の値のみ意味がある vector<int> par, sizes, rank; int num_groups; UnionFind(int n) : par(n), sizes(n, 1), rank(n, 0), num_groups(n) { for (int i = 0; i < n; i++) par[i] = i; } int find(int x) { if (x == par[x]) return x; return par[x] = find(par[x]); // recursive, editing root } void unite(int x, int y) { x = find(x); y = find(y); if (x == y) return; if (rank[x] < rank[y]) swap(x, y); par[y] = x; sizes[x] += sizes[y]; if (rank[x] == rank[y]) rank[x]++; num_groups--; } bool same(int x, int y) { return find(x) == find(y); } int size(int x) { return sizes[find(x)]; } }; int main() { cin.tie(0); ios::sync_with_stdio(false); cout << fixed << setprecision(20); ll n, m, x; cin >> n >> m >> x; GraphL<Edge<mint>> g(n); UnionFind uf(n); rep(i, m){ ll a, b, c; cin >> a >> b >> c; a--; b--; if(!uf.same(a, b)){ uf.unite(a, b); g.add_edge(a, b, mint(x).pow(c)); g.add_edge(b, a, mint(x).pow(c)); } } vector<bool> visited(n, false); mint ans = 0; vll v(n, 1); auto dfs = [&](auto& Self, int node) -> void{ visited[node] = true; for(auto&& e: g[node]){ if(!visited[e.to]){ Self(Self, e.to); v[node] += v[e.to]; ans += e.cost*v[e.to]*(n-v[e.to]); } } }; dfs(dfs, 0); dump(g); dump(v); print(ans); }