求助
查看原帖
求助
717971
liuyi0905楼主2025/1/20 23:07

为什么直接这么写也能过?

#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 5;
int n, m, a[N], s[N], r;
bool f[N];
vector<int> e[N], g[N];
void I(int u, int c) {
  for (auto v : g[u]) {
    c > s[v] && (s[v] = c, I(v, max(c, a[v])), 1);
  }
}
void S(int u) {
  f[u] = 1;
  r = max(r, s[u] - a[u]);
  for (auto v : e[u]) {
    !f[v] && (S(v), 1);
  }
}
int main() {
  cin >> n >> m;
  for (int i = 1; i <= n; i++) { cin >> a[i]; }
  for (int i = 1, u, v, o; i <= m; i++) {
    cin >> u >> v >> o;
    e[u].push_back(v), g[v].push_back(u);
    o ^ 1 && (e[u].push_back(v), g[u].push_back(v), 1);
  }
  s[n] = a[n], I(n, a[n]), S(1);
  cout << r;
  return 0;
}
2025/1/20 23:07
加载中...