結果

問題 No.1502 Many Simple Additions
ユーザー SSRS
提出日時 2021-05-07 22:27:41
言語 C++14
(gcc 13.3.0 + boost 1.87.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
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 5
other AC * 39
権限があれば一括ダウンロードができます

ソースコード

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;
}
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0