結果
| 問題 |
No.921 ずんだアロー
|
| コンテスト | |
| ユーザー |
kyawa
|
| 提出日時 | 2021-12-07 23:29:58 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 826 bytes |
| コンパイル時間 | 1,949 ms |
| コンパイル使用メモリ | 194,656 KB |
| 最終ジャッジ日時 | 2025-01-26 06:38:08 |
|
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 17 WA * 5 |
ソースコード
#include<bits/stdc++.h>
using namespace std;
int main(){
long N; cin >> N;
long cnt = 0;
long last = -1;
vector<long> Acnt;
while(N--){
long a; cin >> a;
if(a == last) cnt++;
else{
if(last != -1) Acnt.push_back(cnt);
cnt = 1;
last = a;
}
}
Acnt.push_back(cnt);
if(Acnt.size() == 1){
cout << Acnt[0] << '\n';
return 0;
}
vector<long> dp(Acnt.size(), 0);
dp[0] = Acnt[0];
if(1 < Acnt.size()) dp[1] = Acnt[1];
if(2 < Acnt.size()) dp[2] = max(dp[0] + Acnt[2], dp[1]);
for(long i = 3; i < Acnt.size(); i++){
dp[i] = max(dp[i], dp[i - 2] + Acnt[i]);
dp[i] = max(dp[i], dp[i - 3] + Acnt[i]);
}
cout << max(dp[Acnt.size() - 2], dp[Acnt.size() - 1]) << '\n';
}
kyawa