답안 #1097863

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1097863 2024-10-08T13:10:56 Z ten_xd Xylophone (JOI18_xylophone) C++17
0 / 100
1 ms 424 KB
#include<bits/stdc++.h>
#include "xylophone.h"
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
#define rep(a,b) for(int a = 0; a < (b); ++a)
#define all(t) t.begin(), t.end()
#define pb push_back

const int NN = 1e6+54321, INF = 2e9+54321;
const ll INF_L = (ll)2e18+54321;

int A[NN], uz[NN];

void solve(int N)
{
	int poczatek = -1, koniec = N;
	while(koniec - poczatek > 1)
	{
		int srodek = (poczatek + koniec) / 2;
		if(query(srodek+1,N) == N-1) poczatek = srodek;
		else koniec = srodek;
	}

	//cout << "POCZATEK: " << poczatek << endl;

	int idx = poczatek;
	A[idx] = 1, uz[1] = 1;
	if(idx-1 >= 0) A[idx-1] = 1+query(idx-1+1,idx+1), uz[A[idx-1]] = 1;
	if(idx+1 < N) A[idx+1] = 1+query(idx+1,idx+2), uz[A[idx+1]] = 1;

	for(int i = idx+2; i < N; ++i)
	{
		int val = query(i-1+1,i+1), lew = A[i-1]-val, praw = A[i-1]+val;
		if(lew < 1 or uz[lew]) A[i] = praw, uz[praw] = 1;
		else if(praw > N or uz[praw]) A[i] = lew, uz[lew] = 1;
		else
		{
			int que = query(i-2+1,i+1);
			if(A[i-2] < lew)
			{
				if(que == lew-A[i-2]) A[i] = lew, uz[lew] = 1;
				else A[i] = praw, uz[praw] = 1;
			}
			else if(A[i-2] > praw)
			{
				if(que == A[i-2]-praw) A[i] = praw, uz[praw] = 1;
				else A[i] = lew, uz[lew] = 1;
			}
			else if(A[i-2] > lew and A[i-2] < A[i-1])
			{
				if(que == A[i-2]-lew) A[i] = lew, uz[lew] = 1;
				else A[i] = praw, uz[praw] = 1;
			}
			else
			{
				if(que == praw-A[i-2]) A[i] = praw, uz[praw] = 1; 
				else A[i] = lew, uz[lew] = 1;
			}
		}
	}

	//cout << "T" << endl;
	//rep(i,N) cout << A[i] << endl;
	//cout << endl;

	for(int i = idx-2; i >= 0; --i)
	{
		int val = query(i+1,i+1+1), lew = A[i+1]-val, praw = A[i+1]+val;
		if(lew < 1 or uz[lew]) A[i] = praw, uz[praw] = 1;
		else if(praw > N or uz[praw]) A[i] = lew, uz[lew] = 1;
		else
		{
			int que = query(i+1,i+2+1);
			if(A[i+2] < lew)
			{
				if(que == lew-A[i+2]) A[i] = lew, uz[lew] = 1;
				else A[i] = praw, uz[praw] = 1;
			}
			else if(A[i+2] > praw)
			{
				if(que == A[i+2]-praw) A[i] = praw, uz[praw] = 1;
				else A[i] = lew, uz[lew] = 1;
			}
			else if(A[i+2] > lew and A[i+2] < A[i+1])
			{
				if(que == A[i+2]-lew) A[i] = lew, uz[lew] = 1;
				else A[i] = praw, uz[praw] = 1;
			}
			else
			{
				if(que == praw-A[i+2]) A[i] = praw, uz[praw] = 1; 
				else A[i] = lew, uz[lew] = 1;
			}
		}
	}

	//cout << "T" << '\n';
	//cout << endl;
	//rep(i,N) cout << A[i] << endl;
	//cout << endl;

	rep(i,N) answer(i+1,A[i]);

}
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 344 KB Output is correct
2 Correct 0 ms 344 KB Output is correct
3 Incorrect 1 ms 424 KB Wrong Answer [7]
4 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 344 KB Output is correct
2 Correct 0 ms 344 KB Output is correct
3 Incorrect 1 ms 424 KB Wrong Answer [7]
4 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 344 KB Output is correct
2 Correct 0 ms 344 KB Output is correct
3 Incorrect 1 ms 424 KB Wrong Answer [7]
4 Halted 0 ms 0 KB -