답안 #261359

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
261359 2020-08-11T16:35:30 Z mjkocijan Lamps (JOI19_lamps) C++14
0 / 100
4 ms 4352 KB
#include <bits/stdc++.h>
using namespace std;
#define X first
#define Y second
#define pb push_back
typedef long long ll;
typedef pair<ll, ll> ii;
#define MAXN 1001001

int n, reza = 0, reza2 = 0;
char a[MAXN], b[MAXN];
int fl[MAXN], t0[MAXN], t1[MAXN], fif[MAXN], fib[MAXN], cf[MAXN], c0[MAXN], c1[MAXN], cfr[MAXN];
int alt_reza = 0;
int gotu[MAXN];
int dp[MAXN], tito[MAXN];

int main()
{
	memset(gotu, -1, sizeof gotu);
	scanf("%d", &n);
	scanf("%s", a);
	scanf("%s", b);
	for (int i = 0; i < n; i++) {
		fl[i] = a[i] != b[i];
		t0[i] = b[i] == '0';
		t1[i] = b[i] == '1';
	}
	for (int i = 0; i < n; i++) {
		if (i == 0) {
			fif[i] = 0;
			fib[i] = 0;
		} else {
			if (fl[i]) fif[i] = fl[i - 1] ? fif[i - 1] : i;
			fib[i] = t0[i - 1] == t0[i] ? fib[i - 1] : i;
			cf[i] = cf[i - 1];
			c0[i] = c0[i - 1];
			c1[i] = c1[i - 1];
		}
		if ((i == n - 1 && fl[i]) || (i < n - 1 && fl[i] && !fl[i + 1])) {
			cf[i]++;
		}
		if (i == n - 1 || (i < n - 1 && t0[i] && !t0[i + 1])) {
			c0[i]++;
			alt_reza++;
		}
		if (i == n - 1 || (i < n - 1 && t1[i] && !t1[i + 1])) {
			c1[i]++;
			if (i < n - 1) alt_reza++;
		}
		//cout << i<<": "<<fl[i]<<' '<<t0[i]<<' '<<t1[i]<<' '<<fif[i]<<' '<<fib[i]<<' '<<cf[i]<<' '<<c0[i]<<' '<<c1[i]<<endl;
	}
	for (int i = n - 1; i >= 0; i--) {
		if (i < n - 1) {
			cfr[i] = cfr[i + 1];
		}
		if ((!i && fl[i]) || (i && fl[i] && !fl[i - 1])) {
			cfr[i]++;
		}
	}
	//for (int i = 0; i < n; i++) {
		//cout << fl[i] << ' ' << cfr[i]<<' '<<cf[i]<<endl;
	//}//
	/*for (int i = 0; i < n; i++) {
		if (i < n - 1 && fl[i] == fl[i + 1]) continue;
		if (!fl[i]) continue;
		reza++;//cout<<i<<' ';
	}//cout<<endl;
	int i2 = 0, i3 = 0;
	for (; i2 < n; i2++) {
		if (t0[i2]) break;
	}
	for (; i3 < n; i3++) {
		if (t1[i3]) break;
	}
	if (max(i2 - 1, i3 - 1) >= 0) reza -= max(0, cf[max(i2 - 1, i3 - 1)] - 1);//printf("%d\n", reza);
	i2 = n - 1; i3 = n - 1;
	for (; i2 >= 0; i2--) {
		if (t0[i2]) break;
	}
	for (; i3 >= 0; i3--) {
		if (t1[i3]) break;
	}
	if (min(i2 + 1, i3 + 1) < n && i2 >= 0 && i3 >= 0) reza -= max(0, cfr[min(i2 + 1, i3 + 1)] - 1);//printf("%d\n", reza);
	for (int i = 0; i < n; i++) {
		if (!t1[i] || (i < n - 1 && t1[i + 1])) continue;
		if (i == n - 1 || fib[i] == 0) continue;
		int ccc = fl[fib[i]];
		if (fl[fib[i] - 1] && fl[i + 1]) reza -= max(0, cf[i] - cf[fib[i] - 1] - ccc);//cout<<i<<'.'<<reza<<' '<<fib[i]<<' '<<fl[fib[i]-1]<<' '<<cf[i]<<' '<<cf[fib[i]-1]<<' '<<ccc<<endl;
		if (!fl[fib[i] - 1] && fl[i + 1]) reza -= max(0, cf[i] - cf[fib[i] - 1] - 1);//cout<<i<<'.'<<reza<<endl;
		if (fl[fib[i] - 1] && !fl[i + 1]) reza -= max(0, cf[i] - cf[fib[i] - 1] - ccc - 1);//cout<<i<<'.'<<reza<<endl;
		if (!fl[fib[i] - 1] && !fl[i + 1]) reza -= max(0, cf[i] - cf[fib[i] - 1] - 1);//cout<<i<<'.'<<reza<<endl;
	}printf("%d\n", reza);
	for (int i = 0; i < n; i++) {
		if (!t0[i] || (i < n - 1 && t0[i + 1])) continue;
		if (i == n - 1 || fib[i] == 0) continue;
		int ccc = fl[fib[i]];
		if (fl[fib[i] - 1] && fl[i + 1]) reza -= max(0, cf[i] - cf[fib[i] - 1] - ccc);
		if (!fl[fib[i] - 1] && fl[i + 1]) reza -= max(0, cf[i] - cf[fib[i] - 1] - 1);
		if (fl[fib[i] - 1] && !fl[i + 1]) reza -= max(0, cf[i] - cf[fib[i] - 1] - ccc - 1);
		if (!fl[fib[i] - 1] && !fl[i + 1]) reza -= max(0, cf[i] - cf[fib[i] - 1] - 1);
	}*/
	/*int zar = 0;
	for (int i = 0; i < n; i++) {
		//if (i < n - 1) continue;
		if (i < n - 1 && t0[i] == t0[i + 1]) continue;
		//cout <<i <<' '<<fib[i]<<endl;
		if ((cf[i] != cf[fib[i]] && cfr[i] != cfr[fib[i]]) || (fl[fib[i]] && fl[i] && fif[i] != fif[fib[i]])) {
		//if (cf[i] != cf[fib[i]] || cfr[i] != cfr[fib[i]]) {
			gotu[fib[i]] = i;cout<<i<<' '<<fib[i]<<" . "<<cf[i]<<' '<<cf[fib[i]]<<endl;
			zar++;
			if (zar >= 3 && zar % 2 == 1) reza2 += 0;
			else {
				reza2++;
				cout<<"!\n";
			}
			//for (int j = fib[i]; j <= i; j++) {
			//	
			//}
		}
		else zar = 0;
	}
	int kile = 0;
	for (int i = 0; i < n; i++) {
		if (gotu[i] > -1) {
			i = gotu[i];
			continue;
		}
		if (!fl[i]) { reza += kile; kile = 0; continue; }
		if (i < n - 1 && gotu[i + 1] > -1) {kile = 1; continue;}
		if (i < n - 1 && fl[i] == fl[i + 1]) continue;
		reza++;
		kile = 0;
		//cout<<i<<' ';
	}*/
	for (int i = 0; i < n; i++) {
		dp[i] = n;
		if (!fl[i] && i) {
			if (dp[i] > dp[i - 1]) {
				dp[i] = dp[i - 1];
				tito[i] = tito[i - 1];
			}
		}
		if (fl[i]) {
			if (dp[i] > 1 + (fif[i] ? dp[fif[i] - 1] : 0)) {
				dp[i] = 1 + (fif[i] ? dp[fif[i] - 1] : 0);
				tito[i] = 0;
			}
		}
		int dalije = (fib[i] && tito[fib[i] - 1] >= 2 && tito[fib[i] - 1] % 2 == 0);
		if (dp[i] > 1 - dalije + (fib[i] ? dp[fib[i] - 1] : 0)) {
			dp[i] = 1 - dalije + (fib[i] ? dp[fib[i] - 1] : 0);
			tito[i] = fib[i] ? 1 + tito[fib[i] - 1] : 1;
		}
		//cout << dp[i] << ' ' << tito[i]<< endl;
	}
	//reza = min(reza, alt_reza);
	//printf("%d\n", reza + reza2 + kile);
	printf("%d\n", dp[n - 1]);
	return 0;
}
/*
29
10000101101100111110001110010
11101110000111000011110001101
*/

Compilation message

lamp.cpp: In function 'int main()':
lamp.cpp:20:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d", &n);
  ~~~~~^~~~~~~~~~
lamp.cpp:21:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%s", a);
  ~~~~~^~~~~~~~~
lamp.cpp:22:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%s", b);
  ~~~~~^~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 4352 KB Output is correct
2 Incorrect 3 ms 4352 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 4352 KB Output is correct
2 Incorrect 3 ms 4352 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 4 ms 4304 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 4352 KB Output is correct
2 Incorrect 3 ms 4352 KB Output isn't correct
3 Halted 0 ms 0 KB -