제출 #455346

#제출 시각아이디문제언어결과실행 시간메모리
455346mjhmjh1104레지스터 (IOI21_registers)C++17
10 / 100
1 ms636 KiB
#include "registers.h"
#include <vector>
using namespace std;

int n, k;
vector<bool> zero(2000);

void compare(int x, int y) {
	append_not(3, y);
	append_or(4, x, 3);
	append_and(5, x, 3);
	append_store(6, zero);
	append_store(7, zero);
	for (int i = 0; i < k; i++) {
		append_and(6, 6, 4);
		append_or(6, 6, 5);
		append_right(4, 4, 1);
		append_right(5, 5, 1);
	}
	append_left(6, 6, 1999);
	append_right(6, 6, 1999);
	for (int i = 1; i < k; i++) {
		append_left(7, 6, 1);
		append_or(6, 6, 7);
	}
	append_and(8, x, 6);
	append_xor(y, y, 8);
	append_and(8, y, 6);
	append_xor(x, x, 8);
	append_and(8, x, 6);
	append_xor(y, y, 8);
}

void construct_instructions(int s, int n, int k, int q) {
	::n = n, ::k = k;
	append_move(1, 0);
	for (int i = 1; i < n; i++) {
		append_right(2, 0, k * i);
		compare(1, 2);
	}
	append_move(0, 1);
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...