結果
問題 | No.5003 物理好きクリッカー |
ユーザー | iehn_ |
提出日時 | 2018-12-06 00:21:11 |
言語 | C++11 (gcc 11.4.0) |
結果 |
AC
|
実行時間 | 316 ms / 10,000 ms |
コード長 | 3,343 bytes |
コンパイル時間 | 1,175 ms |
実行使用メモリ | 21,972 KB |
スコア | 4,377,228,996 |
平均クエリ数 | 10000.00 |
最終ジャッジ日時 | 2021-07-19 08:49:23 |
合計ジャッジ時間 | 13,707 ms |
ジャッジサーバーID (参考情報) |
judge12 / judge10 |
純コード判定しない問題か言語 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 308 ms
21,504 KB |
testcase_01 | AC | 308 ms
21,312 KB |
testcase_02 | AC | 313 ms
21,660 KB |
testcase_03 | AC | 314 ms
21,156 KB |
testcase_04 | AC | 311 ms
21,360 KB |
testcase_05 | AC | 314 ms
21,528 KB |
testcase_06 | AC | 308 ms
21,852 KB |
testcase_07 | AC | 313 ms
21,864 KB |
testcase_08 | AC | 314 ms
21,828 KB |
testcase_09 | AC | 315 ms
21,816 KB |
testcase_10 | AC | 311 ms
21,852 KB |
testcase_11 | AC | 311 ms
21,840 KB |
testcase_12 | AC | 309 ms
21,504 KB |
testcase_13 | AC | 311 ms
21,324 KB |
testcase_14 | AC | 310 ms
21,840 KB |
testcase_15 | AC | 311 ms
21,840 KB |
testcase_16 | AC | 311 ms
21,528 KB |
testcase_17 | AC | 312 ms
21,492 KB |
testcase_18 | AC | 311 ms
21,360 KB |
testcase_19 | AC | 308 ms
21,360 KB |
testcase_20 | AC | 315 ms
21,540 KB |
testcase_21 | AC | 313 ms
21,840 KB |
testcase_22 | AC | 309 ms
21,804 KB |
testcase_23 | AC | 311 ms
21,840 KB |
testcase_24 | AC | 311 ms
21,876 KB |
testcase_25 | AC | 308 ms
21,528 KB |
testcase_26 | AC | 316 ms
21,324 KB |
testcase_27 | AC | 307 ms
21,372 KB |
testcase_28 | AC | 309 ms
21,516 KB |
testcase_29 | AC | 310 ms
21,492 KB |
testcase_30 | AC | 306 ms
21,828 KB |
testcase_31 | AC | 305 ms
21,468 KB |
ソースコード
// C++11 #include <algorithm> #include <cstdlib> #include <iostream> #include <fstream> #include <vector> #include <cmath> #include "bits/stdc++.h" #include <sys/time.h> #include <emmintrin.h> #include <string> #include <bitset> using namespace std; inline long long GetTSC() { long long lo, hi; asm volatile ("rdtsc": "=a"(lo), "=d"(hi)); return lo + (hi << 32); } inline double GetSeconds() { return GetTSC() / 2.8e9; } struct XorShift { uint64_t x = 88172645463325252ULL; XorShift() {} void setSeed(uint64_t seed) { x = seed; } uint64_t next() { x ^= x << 13; x ^= x >> 7; x ^= x << 17; return x; } int nextInt(int n) { uint64_t upper = 0xFFFFFFFFFFFFFFFFULL / n * n; uint64_t v = next(); while (v >= upper) { v = next(); } return v % n; } double nextDouble() { uint64_t v = next() >> 11; // 53bit return (double)v / (1ULL << 53); } }; const double TO = 9.9; const double eps = 1e-7; const double inf = 1e7; const int N = 10000; char S[N]; int R[N]; const int CLICK = 1; const int FM = 5; const string FS[FM] = {"hand", "lily", "factory", "casino", "grimoire"}; const int FP[FM] = {1, 10, 120, 2000, 25000}; const int FB[FM] = {150, (int)2e3, (int)3e4, (int)6e5, (int)1e7}; const int FA[FM] = { 15, (int)2e4, (int)3e5, (int)6e6, (int)1e8}; const int BUY = 2; const int SELL = BUY + FM; const int REF = BUY + FM * 2; double starttime, gt; int tt,ctt; XorShift xs; void init(){ int n; scanf("%d%s", &n, S); } long calc_score(){ long r = 0; return r; } void solve(){ long c = 0; int bcount[FM] = {1, 0, 0, 0, 0}; int acount[FM] = {0, 0, 0, 0, 0}; long bcost[FM]; long acost[FM]; for(int i=0; i<FM; i++){ bcost[i] = FB[i]; acost[i] = FA[i]; } for(int t=0; t<N; t++){ int tr = CLICK; if(t < N - 500){ for(int i=FM-1; i>=0; i--){ if(acost[i] <= c){ tr = REF + i; c -= acost[i]; acount[i]++; acost[i] *= 10; break; } if(bcost[i] <= c){ tr = BUY + i; c -= bcost[i]; bcount[i]++; bcost[i] += bcost[i] / 5 + (bcost[i] % 5 ? 1 : 0); break; } } } R[t] = tr; if(tr == CLICK){ c += bcount[0] * pow(2, acount[0]); } for(int i=1; i<FM; i++){ if(bcount[i] < 1) continue; c += bcount[i] * pow(2, acount[i]) * FP[i]; } } for(int i=0; i<FM; i++){ cerr << "i: " << i << " bc: " << bcount[i] << " ac: " << acount[i] << endl; } cerr << "c: " << c << endl; } void output(){ char s[256]; for(int i=0; i<N; i++){ int ri = R[i]; if(ri == CLICK){ cout << "click" << endl; }else if(ri == REF){ cout << "enhclick" << endl; }else if(ri >= BUY && ri < BUY + FM){ cout << "buy " << FS[ri - BUY] << endl; }else if(ri >= REF && ri < REF + FM){ cout << "reinforce " << FS[ri - REF] << endl; }else if(ri >= SELL && ri < SELL + FM){ cout << "sell " << FS[ri - SELL] << endl; } scanf("%s", s); } } int main() { srand((unsigned) time(NULL)); xs.setSeed(rand() % 65536 || 65537); double mainstart = GetSeconds(); cerr << setprecision(10); init(); cerr << "init_time: " << GetSeconds() - mainstart << endl; solve(); output(); cerr << "main_time: " << GetSeconds() - mainstart << endl; return 0; }