제출 #302742

#제출 시각아이디문제언어결과실행 시간메모리
302742Theo830카니발 티켓 (IOI20_tickets)C++14
27 / 100
758 ms51704 KiB
#include <bits/stdc++.h> #include "tickets.h" using namespace std; typedef int ll; ll INF = 1e9+7; ll MOD = 998244353; typedef pair<long long,ll> ii; #define iii pair<ii,ll> #define f(i,a,b) for(ll i = a;i < b;i++) #define rf(i,a,b) for(ll i=a;i>=b;i--) #define fastio ios_base::sync_with_stdio(0);cin.tie(0);cout.tie(0); #define w(t) while(t--) #define c(n); cin>>n; #define p(n) cout<<n; #define pl(n) cout<<n<<"\n"; #define ps(n); cout<<n<<" "; #define F first #define S second #define pb(a) push_back(a) #define all(x) (x).begin(), (x).end() #define ull unsigned long long #define vll vector<ll> #define vii vector<ii> #define mkp make_pair #define ld long double #define arrin(a,n) f(i,0,n){cin>>a[i];} #define arrout(a,n) f(i,0,n){cout<<a[i]<<" ";} #define printclock cerr<<"Time : "<<*(ld)clock()/(ld)CLOCKS_PER_SEC<<"ms\n"; #define PI (2*acos(0)) #define EPS 1e-18 const long long N = 2e5+5; const long long M = 1e6+5; vll visit,dist,taken; vector<vll> adj,ad; vector<vii> adj2; priority_queue<ii,vector<ii>, greater<ii> > pq; ll bit[N]={0}; ll par[N]={0}; ll an[N][35]; ll depth[N]={0}; ll siz; ll res = 0; ll mycbrt(ll num){ll l = 1,r = 1000000;ll ans = 0;while(l <= r){ll mid = (l+r)/2;if(mid * mid * mid <= num){l = mid + 1;ans = max(ans,mid);}else{r = mid - 1;}}return ans;} ll lcm(ll a,ll b){return (a * b) / __gcd(a,b);} ll gcd(ll a,ll b){return __gcd(a,b);} ll power(ll a,ll b,ll MOD){if(b == 0)return 1;if(b == 1)return a;ll ans = power(a,b/2,MOD) % MOD;ans *= ans;ans %= MOD;if(b % 2 == 1)ans *= a;return ans%MOD;} ll inverse(ll x){x%=MOD;return power(x,MOD-2,MOD);} void BITup(ll k, ll x){while(k <= siz){bit[k]+=x;k += k & -k;}} ll BITq(ll k){ll s=0;while(k>=1){s+=bit[k];k -= k &-k;}return s;} struct point{ll x,y,idx;}; void dfs(ll v){visit[v] = 1;for(auto x:ad[v]){if(!visit[x]){depth[x] = depth[v] + 1;dfs(x);}}} void bfs(ll s){visit[s] = 1;queue<ll>q;q.push(s);while(!q.empty()){ll u = q.front();ps(u);q.pop();for(auto x:adj[u]){if(!visit[x]){visit[x] = 1;q.push(x);}}}} void dijkstra(ll s){pq.push(ii(0,s));dist[s] = 0;while(!pq.empty()){ii f = pq.top();pq.pop();ll w = f.F;ll u = f.S;if(w > dist[u]){continue;}for(auto v:adj2[u]){if(dist[u] + v.S < dist[v.F]){dist[v.F] = dist[u] + v.S;pq.push(ii(dist[v.F],v.F));}}}} void prim(ll edge) {taken[edge] = 1;for(auto v:adj2[edge]) {if (taken[v.first]==0)pq.push(ii(v.second, v.first));}} ll mst(ll s){taken.assign(N, 0);prim(s);ll cost = 0;while(!pq.empty()){ii front = pq.top();pq.pop();ll w = front.first;ll u = front.second;if(taken[u]==0)cost += w;prim(u);}return cost;} void bfs01(ll s){deque<ll>q;dist[s] = 0;q.push_back(s);while(!q.empty()){ll v = q.front();q.pop_front();for(auto x:adj2[v]){if(dist[x.F] > dist[v] + x.S){dist[x.F] = dist[v] + x.S;if(x.S == 0){q.push_front(x.F);}else{q.push_back(x.F);}}}}} void build(ll s,ll p){an[s][0] = p;f(i,1,35){an[s][i] = an[an[s][i-1]][i-1];}for(auto x:adj[s]){if(x != p){depth[x] = depth[s] + 1;build(x,s);}}} ll kth(ll x,ll k){ll ans = x;if(depth[x] < k){return -1;}ll pos = 0;while(k > 0){if(k % 2){ans = an[ans][pos];}pos++;k /= 2;}return ans;} ll lca(ll a,ll b){if(depth[a] > depth[b]){swap(a,b);}b = kth(b,abs(depth[a] - depth[b]));if(a == b){return a;}for(ll i = 34;i >= 0;i--){if(an[a][i] == an[b][i]){continue;}a = an[a][i];b = an[b][i];}return an[a][0];} ll find_dsu(ll x){if(par[x] == x){return x;}par[x] = find_dsu(par[x]);return par[x];} void union_dsu(ll x,ll y){ll pos1 = find_dsu(x);ll pos2 = find_dsu(y);par[pos2] = pos1;} mt19937 rng(chrono::steady_clock::now().time_since_epoch().count()); uniform_int_distribution<ll> distr; ll rnd(ll a, ll b){return distr(rng)%(b-a+1)+a;} void YESNO(ll a){if(!!a){pl("YES");}else{pl("NO");}} void filesin(void){freopen("input.out","r",stdin);} void filesout(void){freopen("tracing.out","w",stdout);} ///I hope I will get uprating and don't make mistakes ///I will never stop programming ///sqrt(-1) Love C++ ///Please don't hack me ///@TheofanisOrfanou Theo830 ///Training /* static int n; static int m; static int k; static std::vector<std::vector<int>> d; static std::vector<std::vector<int>> x; static int called = 0; static void check(bool cond, std::string message) { if (!cond) { printf("%s\n", message.c_str()); exit(0); } } void allocate_tickets( std::vector<std::vector<int>> _d) { check(!called, "allocate_tickets called more than once"); d = _d; check((int)d.size() == n, "allocate_tickets called with parameter of wrong size"); for (int i = 0; i < n; i++) { check((int)d[i].size() == m, "allocate_tickets called with parameter of wrong size"); } called = 1; } */ long long find_maximum(int k, vector<vector<int>> x) { int n = x.size(); int m = x[0].size(); vector<vector<int> > answer; long long ans = 0; vector<iii> arr; ll posa = (n * k) / 2; set<iii>p; f(i,0,n){ vll row; f(j,0,m){ row.pb(-1); } answer.pb(row); f(j,0,k){ ans += x[i][m-k+j]; arr.pb(iii(ii(-x[i][j]-x[i][m-k+j],i),j)); p.insert(iii(ii(i,m-k+j),1)); } } sort(all(arr)); reverse(all(arr)); f(i,0,posa){ ans += arr[i].F.F; p.erase(iii(ii(arr[i].F.S,m-k+arr[i].S),1)); p.insert(iii(ii(arr[i].F.S,arr[i].S),0)); } set<ll>xroma[n]; f(i,0,n){ f(j,0,k){ xroma[i].insert(j); } } ll big[k] = {0},small[k] = {0}; ll pos1 = 0,pos2 = 0; for(auto x:p){ if(x.S){ auto it = xroma[x.F.F].begin(); while(it != xroma[x.F.F].end()){ if(big[(*it)] != n/2){ big[(*it)]++; answer[x.F.F][x.F.S] = (*it); xroma[x.F.F].erase(it); break; } it++; } } else{ auto it = xroma[x.F.F].begin(); while(it != xroma[x.F.F].end()){ if(small[(*it)] != n/2){ small[(*it)]++; answer[x.F.F][x.F.S] = (*it); xroma[x.F.F].erase(it); break; } it++; } } } allocate_tickets(answer); return ans; } /* int main() { assert(scanf("%d %d %d", &n, &m, &k) == 3); x.resize(n); for (int i = 0; i < n; i++) { x[i].resize(m); for (int j=0; j < m; j++) { assert(scanf("%d", &x[i][j]) == 1); } } fclose(stdin); long long answer = find_maximum(k, x); check(called, "failure to call allocate_tickets"); printf("%lld\n", answer); for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { if (j) printf(" "); printf("%d", d[i][j]); } printf("\n"); } fclose(stdout); return 0; } /* /* 2 1 1 500507564 799128524 */

컴파일 시 표준 에러 (stderr) 메시지

tickets.cpp:189:1: warning: "/*" within comment [-Wcomment]
  189 | /*
      |  
tickets.cpp:190:1: warning: "/*" within comment [-Wcomment]
  190 | /*
      |  
tickets.cpp: In function 'long long int find_maximum(int, std::vector<std::vector<int> >)':
tickets.cpp:134:5: warning: unused variable 'pos1' [-Wunused-variable]
  134 |  ll pos1 = 0,pos2 = 0;
      |     ^~~~
tickets.cpp:134:14: warning: unused variable 'pos2' [-Wunused-variable]
  134 |  ll pos1 = 0,pos2 = 0;
      |              ^~~~
tickets.cpp: In function 'void filesin()':
tickets.cpp:66:27: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result]
   66 | void filesin(void){freopen("input.out","r",stdin);}
      |                    ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~
tickets.cpp: In function 'void filesout()':
tickets.cpp:67:28: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result]
   67 | void filesout(void){freopen("tracing.out","w",stdout);}
      |                     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...