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 "registers.h"
#include<bits/stdc++.h>
using namespace std;
using ll = int;
const ll m = 100, b = 2000;
void construct_instructions(int s, int n, int k, int q) {
auto get_num = [&](ll t, ll x, ll i){
append_left(t,x,b-(i+1)*k);
append_right(t,t,b-k);
//append_print(t);
};
vector<bool> zero(b,0);
vector<bool> one(b,0);
one[0] = true;
if (s==0){
get_num(1,0,0);
append_store(m-1,one);
auto neg = [&](ll t, ll x){
append_not(t,x);
append_add(t,t,m-1);
};
auto abs = [&](ll t, ll x, ll tmp){
neg(t,x);
append_right(tmp,x,b-k);
append_and(tmp,t,tmp);
append_not(t,x);
append_right(t,t,b-k);
append_and(t,t,x);
append_add(t,t,tmp);
};
auto uabs = [&](ll t, ll x, ll tmp){
neg(t,x);
append_not(tmp,x);
append_right(tmp,tmp,b-k*2);
append_and(tmp,t,tmp);
append_right(t,x,b-k*2);
append_and(t,t,x);
append_add(t,t,tmp);
};
for(ll i = 1;i<n;i++){
get_num(2,0,i);
neg(3,2);
append_add(3,1,3);
uabs(4,3,5);
//append_print(4);
//append_print(4);
append_add(3,1,2);
//append_print(3);
append_add(3,3,4);
//append_print(3);
append_left(1,3,b-k-1);
append_right(i+1<n,1,b-k);
}
}else{
append_store(m-1,one);
auto neg = [&](ll t, ll x){
append_not(t,x);
append_add(t,t,m-1);
};
auto abs = [&](ll t, ll x, ll tmp){
neg(t,x);
append_right(tmp,x,b-k);
append_and(tmp,t,tmp);
append_not(t,x);
append_right(t,t,b-k);
append_and(t,t,x);
append_add(t,t,tmp);
};
auto uabs = [&](ll t, ll x, ll tmp){
neg(t,x);
append_not(tmp,x);
append_right(tmp,tmp,b-k*2);
append_and(tmp,t,tmp);
append_right(t,x,b-k*2);
append_and(t,t,x);
append_add(t,t,tmp);
};
auto ord = [&](ll l, ll r, ll tmp1, ll tmp2){
neg(tmp1,r);
append_add(tmp1,tmp1,l);
append_add(l,l,r);
abs(tmp2,tmp1,r);
neg(tmp1,tmp2);
append_add(r,l,tmp2);
append_add(l,l,tmp1);
append_right(l,l,1);
append_right(r,r,1);
};
for(ll i = 0;i<n;i++){
get_num(i+1,0,i);
//append_print(i+1);
}
for(ll j = n-1;j>0;j--){
for(ll i = 0;i<j;i++){
ord(i+1,i+2,m-2,m-3);
//append_print(i+1);
//append_print(i+2);
}
}
append_store(0,zero);
for(ll i = 0;i<n;i++){
if(i)append_left(i+1,i+1,i*k);
append_or(0,0,i+1);
}
}
}
Compilation message (stderr)
registers.cpp: In function 'void construct_instructions(int, int, int, int)':
registers.cpp:23:8: warning: variable 'abs' set but not used [-Wunused-but-set-variable]
23 | auto abs = [&](ll t, ll x, ll tmp){
| ^~~
registers.cpp:70:8: warning: variable 'uabs' set but not used [-Wunused-but-set-variable]
70 | auto uabs = [&](ll t, ll x, ll tmp){
| ^~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |