답안 #1081943

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1081943 2024-08-30T13:07:11 Z farica 송신탑 (IOI22_towers) C++17
4 / 100
4000 ms 5700 KB
#include "towers.h"

#include <bits/stdc++.h>

using namespace std;

int n,sub1=1,idx=0;
vector<int> h;

void init(int N, vector<int> H) {
    h.clear();
    sub1 = 1;
    n = N;
    for(auto x : H)
        h.push_back(x);
    int ok=1;
    for(int i=0; i<H.size()-1; i++) {
        if(ok and H[i] > H[i+1]) {
            ok=0;
            idx = i;
        }
        if(!ok and H[i] < H[i+1])
            sub1=0;
    }
}

int max_towers(int L, int R, int D) {
    if(sub1) {
        if(idx > L and idx < R and (h[L]+D) <= h[idx] and (h[R]+D) <= h[idx])
            return 2;
        else
            return 1;
    }
    int ans=1;
    set<int>s;
    map<int,int>m;
    for(int i=L; i<=R; i++) {
        auto it = s.lower_bound(h[i]+D);
        if(it != s.end()) ans = max(ans, m[*it]+1);
        m[h[i]] = ans;
        while(!s.empty() && *(s.begin()) < h[i]) s.erase(s.begin());
        s.insert(h[i]);
    }
    return ans;
}

Compilation message

towers.cpp: In function 'void init(int, std::vector<int>)':
towers.cpp:17:19: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   17 |     for(int i=0; i<H.size()-1; i++) {
      |                  ~^~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 262 ms 1236 KB Output is correct
2 Correct 670 ms 1748 KB Output is correct
3 Correct 628 ms 1748 KB Output is correct
4 Correct 646 ms 1748 KB Output is correct
5 Correct 633 ms 1748 KB Output is correct
6 Correct 659 ms 1748 KB Output is correct
7 Correct 623 ms 1748 KB Output is correct
8 Correct 0 ms 344 KB Output is correct
9 Correct 0 ms 344 KB Output is correct
10 Correct 0 ms 344 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Incorrect 0 ms 344 KB 1st lines differ - on the 1st token, expected: '13', found: '21'
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 0 ms 344 KB 1st lines differ - on the 1st token, expected: '13', found: '21'
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 4038 ms 5700 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 4035 ms 1624 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 0 ms 344 KB 1st lines differ - on the 1st token, expected: '13', found: '21'
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 262 ms 1236 KB Output is correct
2 Correct 670 ms 1748 KB Output is correct
3 Correct 628 ms 1748 KB Output is correct
4 Correct 646 ms 1748 KB Output is correct
5 Correct 633 ms 1748 KB Output is correct
6 Correct 659 ms 1748 KB Output is correct
7 Correct 623 ms 1748 KB Output is correct
8 Correct 0 ms 344 KB Output is correct
9 Correct 0 ms 344 KB Output is correct
10 Correct 0 ms 344 KB Output is correct
11 Incorrect 0 ms 344 KB 1st lines differ - on the 1st token, expected: '13', found: '21'
12 Halted 0 ms 0 KB -