제출 #318540

#제출 시각아이디문제언어결과실행 시간메모리
318540katearima카니발 티켓 (IOI20_tickets)C++14
100 / 100
854 ms60644 KiB
#include "tickets.h" #include <vector> #include <queue> #include <bits/stdc++.h> using namespace std; int i,j,n,m,k; long long sum; pair<int,int> p; priority_queue<pair<int,int>, vector<pair<int,int> >, greater<pair<int,int> > > pq; long long find_maximum(int k, vector<vector<int> > x) { n = x.size(); m = x[0].size(); vector<vector<int> > ans; vector<int> row(m,-1),f(n),v(n); for (int i = 0; i < n; i++) ans.push_back(row); for(i=0; i<n; i++){ for(j=m-k; j<m; j++){ ans[i][j]=-2; sum+=x[i][j]; } } for(i=0; i<n; i++){ int y=x[i][0]+x[i][m-k]; pq.push(make_pair(y,i)); } int y=n*k/2; while(y--){ int a=pq.top().first; int b=pq.top().second; if(f[b]>=k){ pq.pop(); a=pq.top().first; b=pq.top().second; } ans[b][m-k+v[b]]=-1; ans[b][v[b]]=-3; f[b]++; v[b]++; int c=v[b]; sum-=a; if(m-k+c!=m&&c!=m)pq.push(make_pair(x[b][c]+x[b][m-k+c],b)); pq.pop(); } int t=k; int pos=0; int neg=0; for(i=0; i<n; i++){ for(j=0; j<m; j++){ if(ans[i][j]==-3){ ans[i][j]=neg; neg++; if(neg>=k) neg-=k; } }pos=neg; for(j=0; j<m; j++){ if(ans[i][j]==-2){ ans[i][j]=pos; pos++; if(pos>=k) pos-=k; } } } allocate_tickets(ans); return sum; }

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

tickets.cpp: In function 'long long int find_maximum(int, std::vector<std::vector<int> >)':
tickets.cpp:43:6: warning: unused variable 't' [-Wunused-variable]
   43 |  int t=k;
      |      ^
#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...