제출 #1164158

#제출 시각아이디문제언어결과실행 시간메모리
1164158SmuggingSpun메기 농장 (IOI22_fish)C++20
3 / 100
48 ms7264 KiB
#include<bits/stdc++.h> #include "fish.h" using namespace std; typedef long long ll; template<class T>void maximize(T& a, T b){ if(a < b){ a = b; } } ll max_weights(int n, int m, vector<int>X, vector<int>Y, vector<int>W){ bool is_sub1 = true; for(int& x : X){ if(x & 1){ is_sub1 = false; break; } } if(is_sub1){ return accumulate(W.begin(), W.end(), 0LL); } if(*max_element(X.begin(), X.end()) <= 1){ ll sum = 0; vector<vector<pair<int, int>>>p(2); for(int i = 0; i < m; i++){ if(X[i] == 1){ sum += W[i]; p[1].emplace_back(Y[i], W[i]); } else{ p[0].emplace_back(Y[i], W[i]); } } p[1].emplace_back(-1, 0); sort(p[0].begin(), p[0].end()); sort(p[1].begin(), p[1].end()); p[1].emplace_back(n, 0); ll ans = sum; for(int i = 0, j = 0; j + 1 < p[1].size(); j++){ sum -= p[1][j].second; if(p[1][j].first == p[1][j + 1].first){ continue; } while(i < p[0].size() && p[0][i].first < p[1][j + 1].first){ sum += p[0][i].second; i++; } maximize(ans, sum); } return ans; } }

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

fish.cpp: In function 'll max_weights(int, int, std::vector<int>, std::vector<int>, std::vector<int>)':
fish.cpp:51:1: warning: control reaches end of non-void function [-Wreturn-type]
   51 | }
      | ^
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...