Submission #1115357

#TimeUsernameProblemLanguageResultExecution timeMemory
1115357staszic_ojuzArt Exhibition (JOI18_art)C++17
50 / 100
1045 ms72348 KiB
#include<bits/stdc++.h>
using namespace std;
int main() {
    long long n, wiel, wart, l = 0, p = 0, overall = 0;
    cin >> n;
    map<long long, long long> m;
    vector<vector<long long>> v;
    for (int i = 0; i < n; i++) {
        cin >> wiel >> wart;
        m[wiel] += wart;
        overall += wart;
    }
    for (auto [wie, war] : m) {
        v.push_back({wie, war});
    }
    long long wyn = 0, suma = v[0][1], osw = v[v.size() - 1][0];
    for(int i = 0; i < v.size(); i++) {
        //cout << overall << " " << osw << " " << v[i][0] << endl;
        if (overall - osw + v[i][0] > wyn) {
            wyn = overall - osw + v[i][0];
        }
        if (v[i][1] > wyn) {
            wyn = v[i][1];
        }
        overall -= v[i][1];
    }
    while (l < v.size()) {
        //cout << suma << " " << v[l][0] << " " << p << endl;
        if ((l >= p) || (p < v.size() && suma - v[p][0] + v[l][0] > v[p][1])) {
            if (suma - v[p][0] + v[l][0] > wyn) {
                wyn = suma - v[p][0] + v[l][0];
            }
            p += 1;
            if (p < v.size() - 1) {
                suma += v[p][1];
            }
        }
        else {
            suma -= v[l][1];
            l += 1;
        }
    }
    cout << wyn;
}

Compilation message (stderr)

art.cpp: In function 'int main()':
art.cpp:17:22: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   17 |     for(int i = 0; i < v.size(); i++) {
      |                    ~~^~~~~~~~~~
art.cpp:27:14: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::vector<long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   27 |     while (l < v.size()) {
      |            ~~^~~~~~~~~~
art.cpp:29:28: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::vector<long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   29 |         if ((l >= p) || (p < v.size() && suma - v[p][0] + v[l][0] > v[p][1])) {
      |                          ~~^~~~~~~~~~
art.cpp:34:19: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::vector<long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   34 |             if (p < v.size() - 1) {
      |                 ~~^~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...