This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "fish.h"
#include <bits/stdc++.h>
#include <vector>
using namespace std;
using ll = long long;
const ll NINF = -5'000'000'000'000'000;
ll dp[450][15][15][15];
long long max_weights(int N, int M, std::vector<int> X, std::vector<int> Y, std::vector<int> W) {
vector<vector<ll>> fish(N, vector<ll> (N, 0));
//we can consider empty cells to have catfish worth 0
for (int i=0; i<M; i++)
fish[X[i]][Y[i]] = W[i];
ll ans = 0;
for (int r = 0; r < N; r++)
{
for (int i=0; i<=8; i++)
for (int j=0; j<=8; j++)
for (int k=0; k<=8; k++)
{
ll history;
ll current;
history = 0;
if (r!=0)
{
for (int guess = 0; guess<=8; guess++)
history = max(history, dp[r-1][guess][i][j]);
}
if ((r==0) and (i!=0))
current = NINF;
else if ((r==(N-1)) and (k!=0))
current = NINF;
else
{
current = 0;
int reach = max(i, k);
int start = j;
for (int fishy = start+1; fishy<=reach; fishy++)
current += fish[r][fishy];
}
dp[r][i][j][k] = history+current;
ans = max(ans, history+current);
}
}
return ans;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |