Submission #1370054

#TimeUsernameProblemLanguageResultExecution timeMemory
1370054retr0foxxCatfish Farm (IOI22_fish)C++20
6 / 100
40 ms7268 KiB
#include "fish.h"

#include <iostream>
#include <vector>
#include <algorithm>

#define int long long
#define MAXN 300000

int N, M;
std::vector<signed> X, Y, W;

int LR[2][MAXN+5];

long long max_weights(signed _N, signed _M, std::vector<signed> _X, std::vector<signed> _Y,
                      std::vector<signed> _W) {

	N = _N; M = _M;
	X = std::move(_X);
	Y = std::move(_Y);
	W = std::move(_W);
	
	for (int i = 0; i < M; ++i)
	{
		LR[X[i]][Y[i]] = W[i];
	}
	for (int i = 0; i < 2; ++i)
		for (int j = 1; j < N; ++j)
			LR[i][j] += LR[i][j-1];
	
	if (N > 2)
	{
		int best = LR[1][N-1];
		for (int i = 0; i < N; ++i)
		{
			best = std::max(best, LR[1][N-1] - LR[1][i] + LR[0][i]);
		}
		return best;
	}
	else
	{
		return std::max(LR[0][N-1], LR[1][N-1]);
	}
	return 0;
}
#Result Execution timeMemoryGrader output
Fetching results...
#Result Execution timeMemoryGrader output
Fetching results...
#Result Execution timeMemoryGrader output
Fetching results...
#Result Execution timeMemoryGrader output
Fetching results...
#Result Execution timeMemoryGrader output
Fetching results...
#Result Execution timeMemoryGrader output
Fetching results...
#Result Execution timeMemoryGrader output
Fetching results...
#Result Execution timeMemoryGrader output
Fetching results...