답안 #1080137

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1080137 2024-08-29T07:22:29 Z Tozzyyyy 도서관 (JOI18_library) C++17
0 / 100
364 ms 262144 KB
#include <cstdio>
#include <vector>
#include "library.h"
#include <bits/stdc++.h>
using namespace std;

void Solve(int n)
{
	int lst = -1;
	int cur = 1;
	vector<vector<int>> adj(n+1 ,vector<int>());
	
	int cnt = 0;
	while(cnt < n - 1){
		vector<int> t;
		for(int j = 1 ; j <= n ; j++){
			if(cur == j or j == lst) continue;
			t.push_back(j);
		}

		int l = 0 , r = t.size()-1;
		int res = -1;
		while(l <= r){
			int mid = l + r  >> 1;
			vector<int> m(n);
			for(int j = l ; j <=mid ; j++) m[t[j] - 1] = 1;
			int c1 = Query(m);
			m[cur-1] = 1;
			int c2 = Query(m);
			if(c1 == c2) res = mid , r = mid-1;
			else l = mid+1;
		}

		if(res == -1){
			cur = 1;
			assert(adj[1].size() >= 1);
			lst = adj[1][0];
		}else{
			res = t[res];
			adj[cur].push_back(res);
			adj[res].push_back(cur);
			lst = cur , cur = res, cnt++;
		}
	}

	vector<int> res;
	for(int i = 1; i <= n ; i++){
		if(adj[i].size() == 1){
			int t = i , p = i;
			while(1){
				res.push_back(t);
				int c = 0;
				for(auto x : adj[t]) if(x != p) p = t , t = x , c = 1;
				if(c == 0) break;
			}
			break;
		}
	}
	Answer(res);
}

Compilation message

library.cpp: In function 'void Solve(int)':
library.cpp:24:16: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   24 |    int mid = l + r  >> 1;
      |              ~~^~~
# 결과 실행 시간 메모리 Grader output
1 Runtime error 364 ms 262144 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Runtime error 364 ms 262144 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -