# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
761907 | caganyanmaz | Bit Shift Registers (IOI21_registers) | C++17 | 0 ms | 0 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
constexpr static int b = 2000;
void append_move(int t, int y);
void append_store(int t, vector<bool> v);
void append_and(int t, int x, int y);
void append_or(int t, int x, int y);
void append_xor(int t, int x, int y);
void append_not(int t, int x);
void append_left(int t, int x, int p);
void append_right(int t, int x, int p);
void append_add(int t, int x, int y);
void append_print(int t);
void get_second(int t)
{
append_left(t, t, b-2);
append_right(t, t, b-1);
}
void _fix(int t)
{
append_xor(3, t, 2);
get_second(3);
append_not(3);
append_and(t, t, 3);
}
void construct_instructions(int s, int n, int k, int q)
{
if (k == 2)
{
append_right(1, 0, 2);
append_and(2, 0, 1);
_fix(0);
_fix(1);
append_and(0, 0, 1);
}
else
{
append_right(1, 0, 1);
append_and(0, 0, 1);
}
}