結果
問題 |
No.684 Prefix Parenthesis
|
ユーザー |
![]() |
提出日時 | 2025-03-05 19:56:55 |
言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 731 bytes |
コンパイル時間 | 3,306 ms |
コンパイル使用メモリ | 271,836 KB |
実行使用メモリ | 8,612 KB |
最終ジャッジ日時 | 2025-03-05 19:57:01 |
合計ジャッジ時間 | 5,336 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 6 WA * 25 |
コンパイルメッセージ
main.cpp: In function ‘int main()’: main.cpp:13:8: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 13 | scanf("%d %s",&n, s + 1); | ~~~~~^~~~~~~~~~~~~~~~~~~
ソースコード
#include <bits/stdc++.h> #define MAXN 100005 using namespace std; typedef long long LL; int n, dp[MAXN], ans, m[128]; char s[MAXN], c, p; int main() { #ifndef ONLINE_JUDGE freopen("data/data1.in", "r", stdin); // freopen("data/data1.out", "w", stdout); #endif scanf("%d %s",&n, s + 1); m['('] = -1, m[')'] = 1, m['['] = -2, m[']'] = 2; for (int i = 1; s[i]; i++) { c = s[i], p = s[i - 1]; if (m[c] < 0) continue; if (m[c] + m[p] == 0) dp[i] = dp[i - 2] + 2; else if (m[p] > 0 && i - dp[i - 1] - 1 >= 1 && m[c] + m[s[i - dp[i - 1] - 1]] == 0) dp[i] = dp[i - 1] + (i - dp[i - 1] - 2 >= 0 ? dp[i - dp[i - 1] - 2] : 0) + 2; ans = max(ans, dp[i]); } printf("%d", ans); return 0; }