結果

問題 No.3114 0→1
ユーザー daiota
提出日時 2025-04-19 10:36:34
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
WA  
実行時間 -
コード長 1,030 bytes
コンパイル時間 1,865 ms
コンパイル使用メモリ 162,056 KB
実行使用メモリ 7,848 KB
最終ジャッジ日時 2025-04-19 10:36:37
合計ジャッジ時間 3,239 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other WA * 30
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>

using namespace std;

typedef long long ll;
typedef pair<ll,ll> P;
#define REP(i,n) for(ll i=0;i<ll(n);i++)



ll dp[200010][2];




int main(void){
	cin.tie(nullptr);  ios_base::sync_with_stdio(false);
	ll i,j;




	ll N;
	string s;
	cin >> N >> s;
	string S="1";
	S+=s;


	for(i=1;i<=N;i++){
		if(i==1){
			if(S[i]=='1'){
				dp[i][0]=0;
				dp[i][1]=0;
			}else{
				dp[i][0]=0;
				dp[i][1]=1;
			}

		}else{
			if(S[i]=='1'){
				dp[i][0]=dp[i-1][0];
				dp[i][1]=dp[i-1][1];
			}
			else{
				if(S[i-1]=='1' && S[i-2]=='1'){
					dp[i][0]=min(dp[i-1][0],dp[i-1][1]);
					dp[i][1]=dp[i][0]+1;
				}
				else if(S[i-1]=='1' && S[i-2]=='0'){
					dp[i][0]=dp[i-1][1];
					dp[i][1]=min(dp[i-1][0],dp[i-1][1])+1;
				}
				else if(S[i-1]=='0' && S[i-2]=='1'){
					dp[i][0]=dp[i-1][1];
					dp[i][1]=min(dp[i-1][0],dp[i-1][1])+1;
				}
				else{
					dp[i][0]=dp[i-1][1];
					dp[i][1]=min(dp[i-1][0],dp[i-1][1])+1;
				}

			}
		}

	}



	cout << min(dp[N][0],dp[N][1]) << endl;






	return 0;

}

0