Submission #850871

#TimeUsernameProblemLanguageResultExecution timeMemory
850871danikoynovChorus (JOI23_chorus)C++14
16 / 100
3973 ms511544 KiB
/** ____ ____ ____ ____ ____ ____ ||l |||e |||i |||n |||a |||d || ||__|||__|||__|||__|||__|||__|| |/__\|/__\|/__\|/__\|/__\|/__\| **/ #include<bits/stdc++.h> #define endl '\n' using namespace std; typedef long long ll; void speed() { ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); } const int maxn = 510; int n, k; string s; int dp[maxn][maxn][maxn], pos[2][maxn]; /** */ void chmin(int &var, int val) /// careful for long long { var = min(var, val); } void solve() { cin >> n >> k >> s; s = "#" + s; int cntA = 0, cntB =0; for (int i = 1; i <= 2 * n; i ++) { if (s[i] == 'A') { cntA ++; pos[0][cntA] = i; } else { cntB ++; pos[1][cntB] = i; } } for (int i = 0; i <= n; i ++) for (int j = 0; j <= n; j ++) for (int k = 0; k <= n; k ++) dp[i][j][k] = 4 * n * n; /// careful for overflow int cr = 0; for (int j = 1; j <= n; j ++) { cr = cr + pos[0][j] - j; dp[1][j][j] = cr; } for (int i = 1; i <= k; i ++) { for (int j = 1; j <= n; j ++) for (int k = 1; k <= j; k ++) { if (dp[i][j][k] == 4 * n * n) continue; /// i-th song, j open brackets, k - in the last one /// range [j * 2 - k + 1, j * 2] ///cout << "state " << i << " " << j << " " << k << " = " << dp[i][j][k] << endl; int tk = 0, atl = j * 2 - k + 1, atm = j * 2 + 1; for (int fix = 1; fix <= n - j; fix ++) { if (pos[0][fix + j] < atl) tk += atl - pos[0][fix + j]; else if (pos[0][fix + j] > atm) tk += pos[0][fix + j] - atm; //cout << "transition " << fix << " " << tk << endl; ///cout << dp[i][j][k] + tk << " " << tk << endl; chmin(dp[i + 1][j + fix][fix], dp[i][j][k] + tk); atl ++; atm ++; } } } int ans = 4 * n * n; for (int j = 1; j <= n; j ++) ans = min(ans, dp[k][n][j]); cout << ans << endl; } int main() { solve(); return 0; }

Compilation message (stderr)

chorus.cpp: In function 'void solve()':
chorus.cpp:56:5: warning: this 'for' clause does not guard... [-Wmisleading-indentation]
   56 |     for (int i = 0; i <= n; i ++)
      |     ^~~
chorus.cpp:61:9: note: ...this statement, but the latter is misleadingly indented as if it were guarded by the 'for'
   61 |         int cr = 0;
      |         ^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...