Submission #370848

#TimeUsernameProblemLanguageResultExecution timeMemory
370848SortingParrots (IOI11_parrots)C++17
0 / 100
374 ms215396 KiB
#include "encoder.h" #include "encoderlib.h" #include <bits/stdc++.h> using namespace std; const int H = 320 + 256 + 3; const int SZ = 80; struct Big_Number{ int a[SZ]; void init(){ fill(a, a + SZ, 0); } Big_Number(){ init(); } friend Big_Number operator+(const Big_Number &l, const Big_Number &r){ int add = 0; Big_Number ret; for(int i = SZ - 1; i >= 0; --i){ int sum = l.a[i] + r.a[i] + add; ret.a[i] = sum % 256; add = sum / 256; } return ret; } friend bool operator<(const Big_Number &l, const Big_Number &r){ for(int i = 0; i < SZ; ++i) if(l.a[i] != r.a[i]) return l.a[i] < r.a[i]; return false; } }; void output(Big_Number bn){ bool ok = false; for(int i = 0; i < SZ; ++i){ if(bn.a[i]) ok = true; if(ok) cout << bn.a[i] << " "; } cout << endl; } static bool done = false; static Big_Number bc[H][H]; void encode(int n, int m[]){ if(!done){ bc[0][0].a[SZ - 1] = 1; for(int i = 0; i < H; ++i){ bc[i][0].a[SZ - 1] = 1; for(int j = 1; j < i; ++j) bc[i][j] = bc[i - 1][j] + bc[i - 1][j - 1]; if(i) bc[i][i].a[SZ - 1] = 1; } done = true; } output(bc[4][2]); int t = 5 * n, num = 255; Big_Number curr, add; for(int i = 0; i < n; ++i) curr.a[SZ - 1 - i] = m[i]; for(; t > 0; --t){ //cout << num << " num" << endl;; output(bc[t + num - 1][t]); cout << "before" << endl; while(num && curr < bc[t + num - 1][t] + add) num--; //cout << "after" << endl; send(num); add = add + bc[t + num - 1][t]; } cout << "curr: "; output(curr); cout << "add: "; output(add); }
#include "decoder.h" #include "decoderlib.h" #include <bits/stdc++.h> using namespace std; const int H = 320 + 256 + 3; const int SZ = 80; struct Big_Number{ int a[SZ]; void init(){ fill(a, a + SZ, 0); } Big_Number(){ init(); } friend Big_Number operator+(const Big_Number &l, const Big_Number &r){ int add = 0; Big_Number ret; for(int i = SZ - 1; i >= 0; --i){ int sum = l.a[i] + r.a[i] + add; ret.a[i] = sum % 256; add = sum / 256; } return ret; } friend bool operator<(const Big_Number &l, const Big_Number &r){ for(int i = 0; i < SZ; ++i) if(l.a[i] != r.a[i]) return l.a[i] < r.a[i]; return false; } }; static bool done = false; static Big_Number bc[H][H]; void decode(int n, int l, int x[]){ if(!done){ bc[0][0].a[SZ - 1] = 1; for(int i = 0; i < SZ; ++i){ bc[i][0].a[SZ - 1] = 1; for(int j = 1; j <= i; ++j) bc[i][j] = bc[i - 1][j] + bc[i - 1][j - 1]; } done = true; } sort(x, x + l); int t = 5 * n, num = 255; Big_Number curr; for(; t > 0; --t){ int num = x[t - 1]; curr = curr + bc[t + num - 1][t]; } for(int i = 0; i < n; ++i) output(curr.a[SZ - 1 - i]); }

Compilation message (stderr)

decoder.cpp: In function 'void decode(int, int, int*)':
decoder.cpp:51:20: warning: unused variable 'num' [-Wunused-variable]
   51 |     int t = 5 * n, num = 255;
      |                    ^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...