QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#401921#2208. FlowieeAC ✓119ms4248kbC++142.9kb2024-04-29 16:41:492024-04-29 16:41:50

Judging History

你现在查看的是最新测评结果

  • [2024-04-29 16:41:50]
  • 评测
  • 测评结果:AC
  • 用时:119ms
  • 内存:4248kb
  • [2024-04-29 16:41:49]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
template<class Z, class ZC>
struct CostFlow {
  int n;
  vector<vector<tuple<int, int, Z, ZC>>> g;

  CostFlow(int n) : n(n), g(n) {}

  void add(int u, int v, Z c, ZC w) {
    int ru = g[u].size(), rv = g[v].size();
    g[u].emplace_back(v, rv, c, w), g[v].emplace_back(u, ru, 0, -w);
  }

  pair<Z, ZC> dinic(int s, int t) {
    vector<ZC> h(n), dis(n);
    vector<int> level(n), inQueue(n), cur(n);
    auto getH = [&]() {
      fill_n(h.begin(), n, numeric_limits<ZC>::max());
      queue<int> q; q.push(s), h[s] = 0, inQueue[s] = 1;
      while (!q.empty()) {
        int u = q.front(); q.pop(), inQueue[u] = 0;
        for (auto [v, _, c, w]: g[u]) {
          if (c && h[v] > h[u] + w) {
            h[v] = h[u] + w;
            if (!inQueue[v]) q.push(v), inQueue[v] = 1;
          }
        }
      }
    };
    getH();
    if (h[t] == numeric_limits<ZC>::max()) return {0, 0};
    auto getLevel = [&]() {
      fill_n(dis.begin(), n, numeric_limits<ZC>::max());
      priority_queue<pair<ZC, int>, vector<pair<ZC, int>>, greater<pair<ZC, int>>> pQ;
      pQ.emplace(dis[s] = 0, s);
      while (!pQ.empty()) {
        auto [d, u] = pQ.top(); pQ.pop();
        if (d > dis[u]) continue;
        for (auto [v, _, c, w]: g[u]) {
          w += h[u] - h[v];
          if (c && dis[v] > dis[u] + w) pQ.emplace(dis[v] = dis[u] + w, v);
        }
      }
      queue<int> q; fill_n(level.begin(), n, -1), q.push(s), level[s] = 0;
      while (!q.empty()) {
        int u = q.front(); q.pop();
        for (auto [v, _, c, w]: g[u])
          if (c && dis[v] == dis[u] + w + h[u] - h[v] && level[v] == -1) level[v] = level[u] + 1, q.push(v);
      }
    };
    Z ret = 0; ZC cost = 0;
    function<Z(int, Z)> cap = [&](int u, Z lim) {
      if (u == t) return lim;
      Z ret = 0;
      for (; cur[u] && ret < lim; --cur[u]) {
        auto &[v, rev, c, w] = g[u][cur[u] - 1];
        if (c && dis[v] == dis[u] + w + h[u] - h[v] && level[v] == level[u] + 1) {
          Z flow = cap(v, min(lim - ret, c));
          ret += flow, cost += flow * w, c -= flow, get<2>(g[v][rev]) += flow;
          if (ret == lim) return ret;
        }
      }
      return ret;
    };
    while (getLevel(), level[t] != -1) {
      for (int i = 0; i < n; ++i) cur[i] = g[i].size();
      ret += cap(s, numeric_limits<Z>::max());
      for (int i = 0; i < n; ++i) h[i] += dis[i];
    }
    return {ret, cost};
  }
};
constexpr int N = 5005;
int n, m;
int sum[N];
signed main() {
	cin >> n >> m;
	CostFlow<int, int> g(n + 5);
	int res = 0;
	for (int i = 1, u, v, w; i <= m; i++) {
		cin >> u >> v >> w;
		g.add(v, u, w, 1);
		sum[v] += w, sum[u] -= w;
		res += w;
	}
	int S = n + 1, T = n + 2;
	for (int i = 1; i <= n; i++) {
		if (sum[i] > 0) {
			g.add(S, i, sum[i], 0);
		} else {
			g.add(i, T, -sum[i], 0);
		}
	}
	cout << res - g.dinic(S, T).second << "\n";
	return 0;
}

Details

Test #1:

score: 100
Accepted
time: 30ms
memory: 4024kb

Test #2:

score: 0
Accepted
time: 12ms
memory: 3884kb

Test #3:

score: 0
Accepted
time: 24ms
memory: 3824kb

Test #4:

score: 0
Accepted
time: 32ms
memory: 3916kb

Test #5:

score: 0
Accepted
time: 48ms
memory: 3936kb

Test #6:

score: 0
Accepted
time: 43ms
memory: 3972kb

Test #7:

score: 0
Accepted
time: 85ms
memory: 3968kb

Test #8:

score: 0
Accepted
time: 14ms
memory: 3760kb

Test #9:

score: 0
Accepted
time: 27ms
memory: 3916kb

Test #10:

score: 0
Accepted
time: 40ms
memory: 4100kb

Test #11:

score: 0
Accepted
time: 2ms
memory: 3720kb

Test #12:

score: 0
Accepted
time: 40ms
memory: 4096kb

Test #13:

score: 0
Accepted
time: 69ms
memory: 3968kb

Test #14:

score: 0
Accepted
time: 101ms
memory: 4212kb

Test #15:

score: 0
Accepted
time: 3ms
memory: 4084kb

Test #16:

score: 0
Accepted
time: 16ms
memory: 3888kb

Test #17:

score: 0
Accepted
time: 22ms
memory: 3876kb

Test #18:

score: 0
Accepted
time: 6ms
memory: 4060kb

Test #19:

score: 0
Accepted
time: 90ms
memory: 4188kb

Test #20:

score: 0
Accepted
time: 2ms
memory: 3776kb

Test #21:

score: 0
Accepted
time: 38ms
memory: 3924kb

Test #22:

score: 0
Accepted
time: 15ms
memory: 3812kb

Test #23:

score: 0
Accepted
time: 54ms
memory: 3940kb

Test #24:

score: 0
Accepted
time: 37ms
memory: 3912kb

Test #25:

score: 0
Accepted
time: 105ms
memory: 3968kb

Test #26:

score: 0
Accepted
time: 20ms
memory: 3904kb

Test #27:

score: 0
Accepted
time: 7ms
memory: 3828kb

Test #28:

score: 0
Accepted
time: 9ms
memory: 3832kb

Test #29:

score: 0
Accepted
time: 79ms
memory: 3844kb

Test #30:

score: 0
Accepted
time: 86ms
memory: 3928kb

Test #31:

score: 0
Accepted
time: 20ms
memory: 3880kb

Test #32:

score: 0
Accepted
time: 93ms
memory: 3992kb

Test #33:

score: 0
Accepted
time: 41ms
memory: 4144kb

Test #34:

score: 0
Accepted
time: 93ms
memory: 3996kb

Test #35:

score: 0
Accepted
time: 22ms
memory: 4048kb

Test #36:

score: 0
Accepted
time: 70ms
memory: 3908kb

Test #37:

score: 0
Accepted
time: 89ms
memory: 3980kb

Test #38:

score: 0
Accepted
time: 64ms
memory: 4168kb

Test #39:

score: 0
Accepted
time: 34ms
memory: 3924kb

Test #40:

score: 0
Accepted
time: 46ms
memory: 3876kb

Test #41:

score: 0
Accepted
time: 8ms
memory: 3832kb

Test #42:

score: 0
Accepted
time: 12ms
memory: 3812kb

Test #43:

score: 0
Accepted
time: 29ms
memory: 3916kb

Test #44:

score: 0
Accepted
time: 54ms
memory: 3964kb

Test #45:

score: 0
Accepted
time: 75ms
memory: 3912kb

Test #46:

score: 0
Accepted
time: 72ms
memory: 4160kb

Test #47:

score: 0
Accepted
time: 27ms
memory: 3820kb

Test #48:

score: 0
Accepted
time: 59ms
memory: 4192kb

Test #49:

score: 0
Accepted
time: 34ms
memory: 4068kb

Test #50:

score: 0
Accepted
time: 48ms
memory: 3856kb

Test #51:

score: 0
Accepted
time: 12ms
memory: 3880kb

Test #52:

score: 0
Accepted
time: 7ms
memory: 4088kb

Test #53:

score: 0
Accepted
time: 4ms
memory: 3864kb

Test #54:

score: 0
Accepted
time: 97ms
memory: 4008kb

Test #55:

score: 0
Accepted
time: 2ms
memory: 3792kb

Test #56:

score: 0
Accepted
time: 33ms
memory: 3928kb

Test #57:

score: 0
Accepted
time: 11ms
memory: 4052kb

Test #58:

score: 0
Accepted
time: 72ms
memory: 4224kb

Test #59:

score: 0
Accepted
time: 78ms
memory: 3948kb

Test #60:

score: 0
Accepted
time: 72ms
memory: 4208kb

Test #61:

score: 0
Accepted
time: 95ms
memory: 3996kb

Test #62:

score: 0
Accepted
time: 19ms
memory: 4068kb

Test #63:

score: 0
Accepted
time: 26ms
memory: 4144kb

Test #64:

score: 0
Accepted
time: 6ms
memory: 3840kb

Test #65:

score: 0
Accepted
time: 41ms
memory: 3904kb

Test #66:

score: 0
Accepted
time: 83ms
memory: 4168kb

Test #67:

score: 0
Accepted
time: 6ms
memory: 4008kb

Test #68:

score: 0
Accepted
time: 51ms
memory: 3948kb

Test #69:

score: 0
Accepted
time: 28ms
memory: 4088kb

Test #70:

score: 0
Accepted
time: 16ms
memory: 3872kb

Test #71:

score: 0
Accepted
time: 2ms
memory: 3992kb

Test #72:

score: 0
Accepted
time: 7ms
memory: 3796kb

Test #73:

score: 0
Accepted
time: 17ms
memory: 3820kb

Test #74:

score: 0
Accepted
time: 30ms
memory: 3908kb

Test #75:

score: 0
Accepted
time: 13ms
memory: 3876kb

Test #76:

score: 0
Accepted
time: 22ms
memory: 4120kb

Test #77:

score: 0
Accepted
time: 34ms
memory: 3976kb

Test #78:

score: 0
Accepted
time: 102ms
memory: 3968kb

Test #79:

score: 0
Accepted
time: 85ms
memory: 4208kb

Test #80:

score: 0
Accepted
time: 42ms
memory: 3976kb

Test #81:

score: 0
Accepted
time: 19ms
memory: 3808kb

Test #82:

score: 0
Accepted
time: 90ms
memory: 4204kb

Test #83:

score: 0
Accepted
time: 58ms
memory: 3956kb

Test #84:

score: 0
Accepted
time: 45ms
memory: 3928kb

Test #85:

score: 0
Accepted
time: 91ms
memory: 4240kb

Test #86:

score: 0
Accepted
time: 48ms
memory: 4164kb

Test #87:

score: 0
Accepted
time: 2ms
memory: 4004kb

Test #88:

score: 0
Accepted
time: 21ms
memory: 3804kb

Test #89:

score: 0
Accepted
time: 10ms
memory: 3816kb

Test #90:

score: 0
Accepted
time: 102ms
memory: 3936kb

Test #91:

score: 0
Accepted
time: 18ms
memory: 3920kb

Test #92:

score: 0
Accepted
time: 2ms
memory: 3856kb

Test #93:

score: 0
Accepted
time: 20ms
memory: 3836kb

Test #94:

score: 0
Accepted
time: 57ms
memory: 4140kb

Test #95:

score: 0
Accepted
time: 17ms
memory: 3848kb

Test #96:

score: 0
Accepted
time: 5ms
memory: 3784kb

Test #97:

score: 0
Accepted
time: 24ms
memory: 3896kb

Test #98:

score: 0
Accepted
time: 90ms
memory: 3988kb

Test #99:

score: 0
Accepted
time: 0ms
memory: 3748kb

Test #100:

score: 0
Accepted
time: 96ms
memory: 4248kb

Test #101:

score: 0
Accepted
time: 103ms
memory: 4004kb

Test #102:

score: 0
Accepted
time: 116ms
memory: 4020kb

Test #103:

score: 0
Accepted
time: 8ms
memory: 3764kb

Test #104:

score: 0
Accepted
time: 119ms
memory: 4048kb

Test #105:

score: 0
Accepted
time: 31ms
memory: 3824kb

Test #106:

score: 0
Accepted
time: 50ms
memory: 4136kb

Test #107:

score: 0
Accepted
time: 10ms
memory: 3952kb

Test #108:

score: 0
Accepted
time: 30ms
memory: 4140kb

Test #109:

score: 0
Accepted
time: 14ms
memory: 3812kb

Test #110:

score: 0
Accepted
time: 29ms
memory: 3904kb

Test #111:

score: 0
Accepted
time: 17ms
memory: 3824kb

Test #112:

score: 0
Accepted
time: 19ms
memory: 4064kb

Test #113:

score: 0
Accepted
time: 46ms
memory: 3868kb

Test #114:

score: 0
Accepted
time: 56ms
memory: 3872kb

Test #115:

score: 0
Accepted
time: 46ms
memory: 4120kb

Test #116:

score: 0
Accepted
time: 6ms
memory: 3724kb

Test #117:

score: 0
Accepted
time: 21ms
memory: 3764kb

Test #118:

score: 0
Accepted
time: 17ms
memory: 3856kb

Test #119:

score: 0
Accepted
time: 35ms
memory: 3868kb

Test #120:

score: 0
Accepted
time: 37ms
memory: 3936kb

Test #121:

score: 0
Accepted
time: 73ms
memory: 3964kb

Test #122:

score: 0
Accepted
time: 64ms
memory: 3932kb

Test #123:

score: 0
Accepted
time: 31ms
memory: 4084kb

Test #124:

score: 0
Accepted
time: 80ms
memory: 3884kb

Test #125:

score: 0
Accepted
time: 95ms
memory: 4004kb

Test #126:

score: 0
Accepted
time: 29ms
memory: 3892kb

Test #127:

score: 0
Accepted
time: 2ms
memory: 3984kb

Test #128:

score: 0
Accepted
time: 71ms
memory: 3856kb

Test #129:

score: 0
Accepted
time: 50ms
memory: 3888kb

Test #130:

score: 0
Accepted
time: 3ms
memory: 3780kb

Test #131:

score: 0
Accepted
time: 32ms
memory: 3832kb

Test #132:

score: 0
Accepted
time: 9ms
memory: 3892kb

Test #133:

score: 0
Accepted
time: 77ms
memory: 4196kb

Test #134:

score: 0
Accepted
time: 83ms
memory: 4008kb

Test #135:

score: 0
Accepted
time: 66ms
memory: 3896kb

Test #136:

score: 0
Accepted
time: 33ms
memory: 3796kb

Test #137:

score: 0
Accepted
time: 19ms
memory: 3896kb

Test #138:

score: 0
Accepted
time: 27ms
memory: 3888kb

Test #139:

score: 0
Accepted
time: 25ms
memory: 3892kb

Test #140:

score: 0
Accepted
time: 78ms
memory: 3896kb

Test #141:

score: 0
Accepted
time: 84ms
memory: 3992kb

Test #142:

score: 0
Accepted
time: 64ms
memory: 3840kb

Test #143:

score: 0
Accepted
time: 83ms
memory: 3964kb

Test #144:

score: 0
Accepted
time: 72ms
memory: 3944kb

Test #145:

score: 0
Accepted
time: 23ms
memory: 3824kb

Test #146:

score: 0
Accepted
time: 21ms
memory: 3928kb

Test #147:

score: 0
Accepted
time: 38ms
memory: 3940kb

Test #148:

score: 0
Accepted
time: 44ms
memory: 3932kb

Test #149:

score: 0
Accepted
time: 85ms
memory: 4164kb

Test #150:

score: 0
Accepted
time: 7ms
memory: 3720kb

Test #151:

score: 0
Accepted
time: 38ms
memory: 3920kb

Test #152:

score: 0
Accepted
time: 21ms
memory: 3804kb

Test #153:

score: 0
Accepted
time: 94ms
memory: 4000kb

Test #154:

score: 0
Accepted
time: 18ms
memory: 4116kb

Test #155:

score: 0
Accepted
time: 52ms
memory: 4128kb

Test #156:

score: 0
Accepted
time: 97ms
memory: 4180kb

Test #157:

score: 0
Accepted
time: 7ms
memory: 3880kb

Test #158:

score: 0
Accepted
time: 65ms
memory: 3952kb

Test #159:

score: 0
Accepted
time: 95ms
memory: 3952kb

Test #160:

score: 0
Accepted
time: 14ms
memory: 3864kb

Test #161:

score: 0
Accepted
time: 12ms
memory: 4128kb

Test #162:

score: 0
Accepted
time: 9ms
memory: 3832kb

Test #163:

score: 0
Accepted
time: 9ms
memory: 3748kb

Test #164:

score: 0
Accepted
time: 35ms
memory: 3840kb

Test #165:

score: 0
Accepted
time: 8ms
memory: 4032kb

Test #166:

score: 0
Accepted
time: 58ms
memory: 3964kb

Test #167:

score: 0
Accepted
time: 40ms
memory: 3836kb

Test #168:

score: 0
Accepted
time: 100ms
memory: 3976kb

Test #169:

score: 0
Accepted
time: 104ms
memory: 3996kb

Test #170:

score: 0
Accepted
time: 35ms
memory: 3828kb

Test #171:

score: 0
Accepted
time: 65ms
memory: 3948kb

Test #172:

score: 0
Accepted
time: 14ms
memory: 4068kb

Test #173:

score: 0
Accepted
time: 73ms
memory: 3972kb

Test #174:

score: 0
Accepted
time: 22ms
memory: 3868kb

Test #175:

score: 0
Accepted
time: 27ms
memory: 3824kb

Test #176:

score: 0
Accepted
time: 75ms
memory: 3892kb

Test #177:

score: 0
Accepted
time: 11ms
memory: 4068kb

Test #178:

score: 0
Accepted
time: 24ms
memory: 3876kb

Test #179:

score: 0
Accepted
time: 34ms
memory: 3860kb

Test #180:

score: 0
Accepted
time: 4ms
memory: 3820kb

Test #181:

score: 0
Accepted
time: 58ms
memory: 3952kb

Test #182:

score: 0
Accepted
time: 18ms
memory: 3880kb

Test #183:

score: 0
Accepted
time: 18ms
memory: 3880kb

Test #184:

score: 0
Accepted
time: 114ms
memory: 4232kb

Test #185:

score: 0
Accepted
time: 110ms
memory: 3948kb

Test #186:

score: 0
Accepted
time: 110ms
memory: 4008kb