#include #include #include using namespace std; using ll = long long; using ull = unsigned long long; #define rep(i,n) for(int i=0; i<(n); i++) int N,K; int anscnt = 0; string ans; vector bitvec; void push_upd(int i,int x){ anscnt++; ans += "UPD " + to_string(i) + " " + to_string(x) + "\n"; //bitvec[i] = x; //rep(i,N+1) cout << bitvec[i]; cout << endl; } void push_and(int i,int x,int y){ anscnt++; ans += "AND " + to_string(i) + " " + to_string(x) + " " + to_string(y) + "\n"; //bitvec[i] = bitvec[x] & bitvec[y]; //rep(i,N+1) cout << bitvec[i]; cout << endl; } void push_xor(int i,int x,int y){ anscnt++; ans += "XOR " + to_string(i) + " " + to_string(x) + " " + to_string(y) + "\n"; //bitvec[i] = bitvec[x] ^ bitvec[y]; //rep(i,N+1) cout << bitvec[i]; cout << endl; } void add1(int l1,int r1,int b){ for(int i=l1; i>= 1; if(k & 1) push_and(p,i,p); else{ push_upd(i-1,1); push_xor(p,i-1,p); push_xor(i,i-1,i); push_and(p,i,p); push_xor(p,i-1,p); } } } int main(){ cin >> N >> K; //bitvec.resize(N+1,0); //rep(i,N){ char c; cin >> c; bitvec[i] = c-'0'; } for(int i=1; i