제출 #318365

#제출 시각아이디문제언어결과실행 시간메모리
318365katearima카니발 티켓 (IOI20_tickets)C++14
27 / 100
678 ms51892 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(); } vector<vector<int> > pos(n),neg(n); for(i=0; i<n; i++){ for(j=0;j<m; j++){ if(ans[i][j]==-3){ neg[i].push_back(j); } if(ans[i][j]==-2){ pos[i].push_back(j); } } } int t=k; while(t--){ vector<int> v(n); int g=0; for(i=0; i<pos.size(); i++){ if(pos[i].size()<=1) continue; if(g==n/2) break; int h=pos[i].back(); ans[i][h]=t; pos[i].pop_back(); g++; v[i]=1; } if(g!=n/2){ for(i=0; i<pos.size(); i++){ if(pos[i].size()!=1||v[i]==1) continue; if(g==n/2) break; int h=pos[i].back(); ans[i][h]=t; pos[i].pop_back(); g++; v[i]=1; } } g=0; for(i=0; i<neg.size(); i++){ if(neg[i].size()<=1|| v[i]==1) continue; if(g==n/2) break; int h=neg[i].back(); ans[i][h]=t; //cout<<i<<" "<<h<<endl; neg[i].pop_back(); g++; v[i]=1; } if(g!=n/2){ for(i=0; i<neg.size(); i++){ if(neg[i].size()!=1||v[i]==1) continue; if(g==n/2) break; int h=neg[i].back(); ans[i][h]=t; //cout<<i<<" "<<h<<endl; neg[i].pop_back(); g++; } } v.clear(); } allocate_tickets(ans); return sum; }

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

tickets.cpp: In function 'long long int find_maximum(int, std::vector<std::vector<int> >)':
tickets.cpp:59:13: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   59 |   for(i=0; i<pos.size(); i++){
      |            ~^~~~~~~~~~~
tickets.cpp:69:14: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   69 |    for(i=0; i<pos.size(); i++){
      |             ~^~~~~~~~~~~
tickets.cpp:80:13: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   80 |   for(i=0; i<neg.size(); i++){
      |            ~^~~~~~~~~~~
tickets.cpp:91:14: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   91 |    for(i=0; i<neg.size(); i++){
      |             ~^~~~~~~~~~~
#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...