제출 #1356034

#제출 시각아이디문제언어결과실행 시간메모리
1356034crispxxXylophone (JOI18_xylophone)C++20
47 / 100
17 ms464 KiB
#include "xylophone.h"

#include <bits/stdc++.h>

using namespace std;

#define nl '\n'

using ll = long long;

int ask(int l, int r) {
	return query(l + 1, r + 1);
}

int find_one(int n) {
	int l = 0, r = n - 1;
	
	while(l < r) {
		int mid = (l + r + 1) >> 1;
		
		if(ask(mid, n - 1) == n - 1) l = mid;
		else r = mid - 1;
	}
	
	return l;
}

void solve(int n) {
	int i1 = find_one(n);
	
	vector<int> a(n);
	
	a[i1] = 1;
	
	vector<array<int, 2>> dif(n);
	
	for(int i = 0; i < n; i++) {
		if(i >= 1) dif[i][0] = ask(i - 1, i);
		if(i >= 2) dif[i][1] = ask(i - 2, i);
	}
	
	for(int i = i1 + 1; i < n; i++) {
		if(i == i1 + 1) {
			a[i] = a[i - 1] + dif[i][0];
		} else {
			
			if(a[i - 2] < a[i - 1]) {
				if(dif[i - 1][0] + dif[i][0] == dif[i][1]) {
					a[i] = a[i - 1] + dif[i][0];
				} else {
					a[i] = a[i - 1] - dif[i][0];
				}
			} else {
				if(dif[i - 1][0] + dif[i][0] == dif[i][1]) {
					a[i] = a[i - 1] - dif[i][0];
				} else {
					a[i] = a[i - 1] + dif[i][0];
				}
			}
			
		}
	}
	
	for(int i = i1 - 1; i >= 0; i--) {
		if(i == i1 - 1) {
			a[i] = a[i + 1] + dif[i + 1][0];
		} else {
			
			if(a[i + 2] < a[i + 1]) {
				if(dif[i + 2][0] + dif[i + 1][0] == dif[i + 2][1]) {
					a[i] = a[i + 1] + dif[i + 1][0];
				} else {
					a[i] = a[i + 1] - dif[i + 1][0];
				}
			} else {
				if(dif[i + 2][0] + dif[i + 1][0] == dif[i + 2][1]) {
					a[i] = a[i + 1] - dif[i + 1][0];
				} else {
					a[i] = a[i + 1] + dif[i + 1][0];
				}
			}
			
		}
	}
	
	// cout << "here: " << nl;
	
	// for(int i = 0; i < n; i++) {
		// cout << a[i] << ' ';
	// }
	
	// cout << nl;
	
	for(int i = 0; i < n; i++) answer(i + 1, a[i]);
}

/**

**/

#결과 실행 시간메모리채점기 출력
결과를 불러오는 중입니다…
#결과 실행 시간메모리채점기 출력
결과를 불러오는 중입니다…
#결과 실행 시간메모리채점기 출력
결과를 불러오는 중입니다…