답안 #800800

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
800800 2023-08-01T21:10:46 Z biank 자동 인형 (IOI18_doll) C++14
6 / 100
135 ms 15184 KB
#include "doll.h"
#include <bits/stdc++.h>

using namespace std;

#define SIZE(x) (int)x.size()

void create_circuit(int M, vector<int> A) {
	
	int N = SIZE(A);
	vector <int> C(M+1);
	vector <int> X, Y;
	if (M == 1) {
		X.resize(N-1);
		Y.resize(N-1);
		
  C[0] = 1;
  if (N == 1) {
	  C[1] = 0;
	  answer(C,X,Y);
	  return;
	}
	
	if (N == 2) {
		C[1] = -1;
		X[0] = 1;
		Y[0] = 0;
		answer(C,X,Y);
		return;
	}
	
	C[1] = -1;
	X[0] = 1;
	Y[0] = -2;
	
	
	for (int i=1; i<N-2; i++) {
		X[i] = -i;
		Y[i] = -i-2;
		//cerr << X[i] << ' ' << Y[i] << endl;
	}
	
	X[N-2] = -N+2;
	Y[N-2] = 0;
	} else {
	A.push_back(0);
	map <int, vector <int>> next;
	for (int i=0; i<N; i++) {
		next[A[i]].push_back(A[i+1]);
		//Scerr << A[i] << ' ' << A[i+1] << endl;
	}
	
	C[0] = A[0];
	int j = 0;
	for (auto &x:next) {
		int a = x.first;
		vector <int> n = x.second;
		int S = SIZE(n);
		if (S == 1) {
			C[a] = n[0];
			continue;
		}
		if (S == 2) {
			C[a] = --j;
			X.push_back(n[0]);
			Y.push_back(n[1]);
			continue;
		}
		if (S == 3 || S == 4) {
			C[a] = --j;
			X.push_back(--j);
			Y.push_back(--j);
			X.push_back(n[0]);
			Y.push_back(n[2]);
			X.push_back(n[1]);
			Y.push_back(S == 3 ? j : n[3]);
		}
	}
	
}
  
  
  /*for (int i=0; i<=M; i++) {
	  cerr << C[i] << " ";
  }
  cerr << endl;*/

  
  answer(C, X, Y);
}
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 300 KB Output is correct
2 Correct 37 ms 8496 KB Output is correct
3 Correct 34 ms 8264 KB Output is correct
4 Correct 0 ms 212 KB Output is correct
5 Correct 9 ms 1492 KB Output is correct
6 Correct 78 ms 12556 KB Output is correct
7 Correct 1 ms 212 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 300 KB Output is correct
2 Correct 37 ms 8496 KB Output is correct
3 Correct 34 ms 8264 KB Output is correct
4 Correct 0 ms 212 KB Output is correct
5 Correct 9 ms 1492 KB Output is correct
6 Correct 78 ms 12556 KB Output is correct
7 Correct 1 ms 212 KB Output is correct
8 Correct 64 ms 10100 KB Output is correct
9 Correct 75 ms 12308 KB Output is correct
10 Correct 108 ms 15184 KB Output is correct
11 Correct 0 ms 212 KB Output is correct
12 Correct 0 ms 300 KB Output is correct
13 Correct 0 ms 212 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 300 KB Output is correct
2 Correct 37 ms 8496 KB Output is correct
3 Correct 34 ms 8264 KB Output is correct
4 Correct 0 ms 212 KB Output is correct
5 Correct 9 ms 1492 KB Output is correct
6 Correct 78 ms 12556 KB Output is correct
7 Correct 1 ms 212 KB Output is correct
8 Correct 64 ms 10100 KB Output is correct
9 Correct 75 ms 12308 KB Output is correct
10 Correct 108 ms 15184 KB Output is correct
11 Correct 0 ms 212 KB Output is correct
12 Correct 0 ms 300 KB Output is correct
13 Correct 0 ms 212 KB Output is correct
14 Incorrect 135 ms 12952 KB state 'Y'
15 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 0 ms 212 KB wrong motion
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 212 KB Output is correct
2 Incorrect 27 ms 4448 KB over 20000000 inversions
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 212 KB Output is correct
2 Incorrect 27 ms 4448 KB over 20000000 inversions
3 Halted 0 ms 0 KB -