結果
問題 | No.1589 Bit Vector |
ユーザー |
👑 ![]() |
提出日時 | 2021-07-08 22:50:07 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,235 bytes |
コンパイル時間 | 1,421 ms |
コンパイル使用メモリ | 82,472 KB |
最終ジャッジ日時 | 2025-01-22 18:59:02 |
ジャッジサーバーID (参考情報) |
judge5 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | WA * 1 |
other | AC * 2 WA * 33 |
ソースコード
#include <iostream> #include <vector> #include <map> 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; string ans; void push_upd(int i,int x){ ans += "UPD " + to_string(i) + " " + to_string(x) + "\n"; } void push_and(int i,int x,int y){ ans += "AND " + to_string(i) + " " + to_string(x) + " " + to_string(y) + "\n"; } void push_xor(int i,int x,int y){ ans += "XOR " + to_string(i) + " " + to_string(x) + " " + to_string(y) + "\n"; } void add1(int l1,int r1,int b){ for(int i=l1; i<r1; i++){ push_and(N,i,b); push_xor(i,i,b); push_and(b,N,N); } push_and(r1,b,b); } void comp(int l1,int r1,int k,int p){ if(k & 1) push_and(p,l1,l1); else push_upd(p,1); for(int i=l1+1; i<r1; i++){ k >>= 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; for(int i=1; i<N; i++) add1(0,min(i,10),i); comp(0,min(N,10),K,N); cout << ans; return 0; } struct ios_do_not_sync{ ios_do_not_sync(){ ios::sync_with_stdio(false); cin.tie(nullptr); } } ios_do_not_sync_inst;