제출 #165262

#제출 시각아이디문제언어결과실행 시간메모리
165262Bojack3단 점프 (JOI19_jumps)C++14
27 / 100
71 ms7272 KiB
#include <bits/stdc++.h>

using namespace std;

typedef long long ll;

void solve() {
  int n; scanf("%d", &n);
  vector <int> a(n);
  for(int i = 0; i < n; i++) {
    scanf("%d", &a[i]);
  }
  int q; scanf("%d", &q);
  while(q--) {
    int l, r; scanf("%d", &l, &r);
  }
  stack <pair<int, int>> s;
  vector <pair <int, int>> can;
  for(int i = n - 1; i >= 0; i--) {
    while(!s.empty() and s.top().first < a[i]) {
      s.pop();
    }
    if(s.empty()) {
      
    } else {
        can.push_back({i, s.top().second});
    }
    s.push({a[i], i});
  }
  while(!s.empty()) s.pop();
  for(int i = 0; i < n; i++) {
    while(!s.empty() and s.top().first < a[i]) {
      s.pop();
    }
    if(s.empty()) {
      
    } else {
        can.push_back({s.top().second, i});
    }
    s.push({a[i], i});
  }
  vector <int> mx(n);
  mx[n - 1] = a[n - 1];
  for(int i = n - 2; i >= 0; i--) {
    mx[i] = max(mx[i + 1], a[i]);
  }
  int ans = 0;
  for(auto p : can) {
    int i = p.first;
    int j = p.second;
    if(i > j) swap(i, j);
    if(j + j - i < n) ans = max(ans, a[i] + a[j] + mx[j + j - i]);
  }
  printf("%d\n", ans);
}

int main() {
  solve();
}

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

jumps.cpp: In function 'void solve()':
jumps.cpp:15:33: warning: too many arguments for format [-Wformat-extra-args]
     int l, r; scanf("%d", &l, &r);
                                 ^
jumps.cpp:8:15: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   int n; scanf("%d", &n);
          ~~~~~^~~~~~~~~~
jumps.cpp:11:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     scanf("%d", &a[i]);
     ~~~~~^~~~~~~~~~~~~
jumps.cpp:13:15: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   int q; scanf("%d", &q);
          ~~~~~^~~~~~~~~~
jumps.cpp:15:20: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     int l, r; scanf("%d", &l, &r);
               ~~~~~^~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...