結果

問題 No.1502 Many Simple Additions
ユーザー SSRSSSRS
提出日時 2021-05-07 22:27:41
言語 C++14
(gcc 12.3.0 + boost 1.83.0)
結果
AC  
実行時間 155 ms / 2,000 ms
コード長 2,304 bytes
コンパイル時間 1,969 ms
コンパイル使用メモリ 185,544 KB
実行使用メモリ 11,092 KB
最終ジャッジ日時 2024-09-15 18:18:47
合計ジャッジ時間 5,335 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
6,816 KB
testcase_01 AC 2 ms
6,940 KB
testcase_02 AC 2 ms
6,944 KB
testcase_03 AC 2 ms
6,944 KB
testcase_04 AC 2 ms
6,944 KB
testcase_05 AC 2 ms
6,940 KB
testcase_06 AC 2 ms
6,944 KB
testcase_07 AC 2 ms
6,940 KB
testcase_08 AC 2 ms
6,944 KB
testcase_09 AC 2 ms
6,940 KB
testcase_10 AC 2 ms
6,940 KB
testcase_11 AC 2 ms
6,944 KB
testcase_12 AC 2 ms
6,940 KB
testcase_13 AC 2 ms
6,944 KB
testcase_14 AC 2 ms
6,940 KB
testcase_15 AC 2 ms
6,940 KB
testcase_16 AC 2 ms
6,940 KB
testcase_17 AC 2 ms
6,944 KB
testcase_18 AC 2 ms
6,940 KB
testcase_19 AC 2 ms
6,940 KB
testcase_20 AC 2 ms
6,944 KB
testcase_21 AC 2 ms
6,944 KB
testcase_22 AC 2 ms
6,940 KB
testcase_23 AC 2 ms
6,940 KB
testcase_24 AC 2 ms
6,944 KB
testcase_25 AC 2 ms
6,944 KB
testcase_26 AC 2 ms
6,940 KB
testcase_27 AC 116 ms
10,168 KB
testcase_28 AC 117 ms
10,160 KB
testcase_29 AC 17 ms
7,172 KB
testcase_30 AC 152 ms
10,980 KB
testcase_31 AC 155 ms
11,092 KB
testcase_32 AC 148 ms
10,964 KB
testcase_33 AC 132 ms
8,644 KB
testcase_34 AC 132 ms
8,812 KB
testcase_35 AC 132 ms
8,688 KB
testcase_36 AC 101 ms
8,728 KB
testcase_37 AC 101 ms
8,724 KB
testcase_38 AC 104 ms
7,924 KB
testcase_39 AC 66 ms
6,940 KB
testcase_40 AC 33 ms
6,940 KB
testcase_41 AC 9 ms
6,940 KB
testcase_42 AC 123 ms
9,920 KB
testcase_43 AC 2 ms
6,940 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
const long long MOD = 1000000007;
int main(){
  int N, M, K;
  cin >> N >> M >> K;
  vector<vector<pair<int, int>>> E(N);
  for (int i = 0; i < M; i++){
    int X, Y, Z;
    cin >> X >> Y >> Z;
    X--;
    Y--;
    E[X].push_back(make_pair(Z, Y));
    E[Y].push_back(make_pair(Z, X));
  }
  vector<long long> ans(2, 1);
  for (int i = 0; i < 2; i++){
    if (i == 1){
      K--;
    }
    vector<bool> used(N, false);
    vector<long long> a(N), b(N);
    for (int j = 0; j < N; j++){
      if (!used[j]){
        used[j] = true;
        a[j] = 1;
        b[j] = 0;
        long long mn = 1, mx = K;
        vector<long long> s;
        bool ok = true;
        queue<int> Q;
        Q.push(j);
        while (!Q.empty()){
          int v = Q.front();
          Q.pop();
          if (a[v] == 1){
            mn = max(mn, 1 - b[v]);
            mx = min(mx, K - b[v]);
          }
          if (a[v] == -1){
            mn = max(mn, b[v] - K);
            mx = min(mx, b[v] - 1);
          }
          for (auto P : E[v]){
            int w = P.second;
            if (!used[w]){
              used[w] = true;
              a[w] = -a[v];
              b[w] = P.first - b[v];
              Q.push(w);
            } else if (a[v] != a[w]){
              if (b[v] + b[w] != P.first){
                ok = false;
              }
            } else {
              if (a[v] == 1 && a[w] == 1){
                s.push_back(P.first - b[v] - b[w]);
              }
              if (a[v] == -1 && a[w] == -1){
                s.push_back(b[v] + b[w] - P.first);
              }
            }
          }
        }
        if (!ok){
          ans[i] = 0;
        } else {
          sort(s.begin(), s.end());
          s.erase(unique(s.begin(), s.end()), s.end());
          if (s.size() >= 2){
            ans[i] = 0;
          } else if (s.size() == 1){
            if (s[0] % 2 == 1){
              ans[i] = 0;
            } else {
              if (s[0] / 2 < mn || s[0] / 2 > mx){
                ans[i] = 0;
              }
            }
          } else {
            long long tmp = max(mx - mn + 1, (long long) 0);
            ans[i] *= tmp;
            ans[i] %= MOD;
          }
        }
      }
    }
  }
  cout << (ans[0] - ans[1] + MOD) % MOD << endl;
}
0