#include #define rep(i,n) for(int i=0; i=0; i--) #define pers(i,n,s) for(int i=n-1; i>=s; i--) #define all(v) v.begin(),v.end() #define fi first #define se second #define pb push_back #define si(v) int(v.size()) #define lb(v,n) lower_bound(all(v),n) #define lbi(v,n) int(lower_bound(all(v),n) - v.begin()) #define ub(v,n) upper_bound(all(v),n) #define ubi(v,n) int(upper_bound(all(v),n) - v.begin()) #define mod 1000000007 #define infi 1010000000 #define infl 1100000000000000000 #define outve(v) {for(auto i : v) cout << i << " ";cout << endl;} #define outmat(v) for(auto i : v){for(auto j : i) cout << j << " ";cout << endl;} #define errve(v) {for(auto i : v) cout << i << " ";cout << endl;} #define errmat(v) for(auto i : v){for(auto j : i) cout << j << " ";cout << endl;} #define in(n,v) for(int i=0; i<(n); i++){cin >> v[i];} #define IN(n,m,v) rep(i,n) rep(j,m){cin >> v[i][j];} #define cyes cout << "Yes" << endl #define cno cout << "No" << endl #define cYES cout << "YES" << endl #define cNO cout << "NO" << endl #define csp << " " << #define outset(n) cout << fixed << setprecision(n); using namespace std; using ll = long long; using ull = unsigned long long; using uint = unsigned int; using ld = long double; using vi = vector; using vvi = vector>; using vd = vector; using vvd = vector>; using vl = vector; using vvl = vector>; using vs = vector; using pii = pair; using pll = pair; template using ve = vector; template using vv = vector>; template using pq2 = priority_queue; template using pq1 = priority_queue,greater>; template bool chmax(T &a, T b) {if(a < b) {a = b;return 1;}return 0;} template bool chmin(T &a, T b) {if(a > b) {a = b;return 1;}return 0;} int popcnt(uint n) {return __builtin_popcount(n);} int popcntl(ull n) {return __builtin_popcountll(n);} int bsr(uint n) {return 31 - __builtin_clz(n);} int bsrl(ull n) {return 63 - __builtin_clzll(n);} int bsf(uint n) {return __builtin_ctz(n);} int bsfl(ull n) {return __builtin_ctzll(n);} double TIME_LIMIT = 1.5; int LOCAL = 0; int TEATER = 0; unsigned int xorshift() { static unsigned int tx = 123456789, ty=362436069, tz=521288629, tw=88675123; unsigned int tt = (tx^(tx<<11)); tx = ty; ty = tz; tz = tw; return ( tw=(tw^(tw>>19))^(tt^(tt>>8)) ); } class Timer { int ti; double time; public: Timer(){} void start(){ti = clock();} inline double get_time(){return time = (LOCAL==1 ? 2.0 : 1.0) * (clock() - ti) / CLOCKS_PER_SEC;} inline double now(){return time;} }; constexpr int dh[4] = {-1,0,1,0}; constexpr int dw[4] = {0,-1,0,1}; constexpr int N = 14; constexpr int M = 30000; constexpr int T = 400; class SimulatedAnnealing { Timer timer; ll score; int home[M]; int company[M]; int D[196][196]; int road[N][N]; int road_num = 0; vi road_x; /* ll money_now = 1000000; ll people_now = 0; int R_now[N][N]; pair tester_in(){ return make_pair(money_now,people_now); } void tester_out(int t, int h=-1, int w=-1, int k=-1){ if(t == 3) money_now += 50000; else if(t == 2) people_now++; else { money_now -= 10000000ll/sqrt(people_now); ll d[196][196]; int cn[196][196]; rep(i,N) rep(j,N){ int s = i*N+j; rep(h,N) rep(w,N) d[s][h*N+w] = infi; rep(h,N) rep(w,N) cn[s][h*N+w] = 0; d[s][s] = 0; pq1 pq; pq.push(0*10000+i*100+j); while (!pq.empty()) { ll chw = pq.top(); pq.pop(); ll c = chw/10000; int h = (chw%10000)/100, w = chw%100; if(d[s][h*N+w] < c) continue; rep(k,4) { int nh = h + dh[k], nw = w + dw[k]; if(nh < 0 || nh >= N || nw < 0 || nw >= N) continue; if(chmin(d[s][nh*N+nw], c+(road[h][w]&1<> m >> t; rep(i,M) { int a,b,c,d; cin >> a >> b >> c >> d; a--,b--,c--,d--; home[i] = a*N+b; company[i] = c*N+d; } score = 0; } inline bool can_move(int h, int w, int k){ int nh = h + dh[k], nw = w + dw[k]; if(nh < 0 || nh >= N || nw < 0 || nw >= N) return false; return true; } ll cal_score(){ ll res = -10000000LL*(ll)road_num; ll d[196][196]; int cn[196][196]; rep(i,N) rep(j,N){ int s = i*N+j; rep(h,N) rep(w,N) d[s][h*N+w] = infi; rep(h,N) rep(w,N) cn[s][h*N+w] = 0; d[s][s] = 0; pq1 pq; pq.push(0*10000+i*100+j); while (!pq.empty()) { ll chw = pq.top(); pq.pop(); ll c = chw/10000; int h = (chw%10000)/100, w = chw%100; if(d[s][h*N+w] < c) continue; rep(k,4) { int nh = h + dh[k], nw = w + dw[k]; if(nh < 0 || nh >= N || nw < 0 || nw >= N) continue; if(chmin(d[s][nh*N+nw], c+(road[h][w]&1<(road[i][j]) << " "; // cerr << endl; // } /* int loop = 0; double T1 = 10, T0 = 0; double T = T1; while (timer.now() < TIME_LIMIT) { loop++; ll score0 = score; int road_num0 = road_num; int road0[N][N]; vi road_x0 = road_x; rep(i,N) rep(j,N) road0[i][j] = road[i][j]; int p = xorshift()%100; if(p <= 100){ int n = xorshift()%road_num; int a = road_x[n]/1000, b = (road_x[n]%1000)/10, k = road_x[n]%10; road[a][b] &= ~(1<(road[i][j]) << " "; // cerr << endl; // } cerr << score csp road_num csp timer.get_time() << endl; */ solve1(); } void solve1(){ ll money = 1000000, people = 0; int road_build = 0; rep(t,T){ cin >> money >> people; if(road_build < road_num){ if(people > 0 && money > 100+(10000000ll/sqrt(people))){ int x = road_x[road_build]/1000, y = (road_x[road_build]%1000)/10, k = road_x[road_build]%10; int z = x + dh[k], w = y+dw[k]; cout << 1 csp x+1 csp y+1 csp z+1 csp w+1 << endl; road_build++; }else{ if(people < 30) { cout << 2 << endl; }else{ cout << 3 << endl; } } }else{ cout << 3 << endl; } cout.flush(); } } }; int main(){ ios::sync_with_stdio(false); cin.tie(nullptr); SimulatedAnnealing solver; solver.solve(); return 0; }