제출 #1354113

#제출 시각아이디문제언어결과실행 시간메모리
1354113takoshanavaA Difficult(y) Choice (BOI21_books)C++20
0 / 100
1 ms412 KiB
#include <bits/stdc++.h>
#include "books.h"
//#define int long long
#define ll long long
#define pb push_back
#define fs first
#define sc second
using namespace std;

void solve(int n, int k, long long a, int s){
    vector<int> vec; 
    ll sum = 0;
    for(int i = 1; i <= k; i++){
        int v = skim(i); vec.pb(v), sum += v;
    }
    for(int i = max(k + 1, n - k + 1); i <= n; i++) vec.pb(skim(i));

    if(sum > 2 * a) impossible();

    int r = k, l = 1;
    vector<int> res;
    while(r < n){
        sum -= vec[l];
        r++;
        sum += vec[r];
        if(sum >= a and sum <= 2 * a){
            for(int i = l; i <= r; i++) res.pb(i);
            answer(res);
        }
        l++;
    }
    if(sum < a) impossible();
    int val;
    l = 1, r = n;
    while(l <= r){
        int mid = (l + r) / 2;
        int v = skim(mid);
        if(v > a) r = mid - 1;
        else l = mid + 1, val = v;
    }

    vector<int> vec1;
    for(int i = 0; i < k; i++) vec1.pb(vec[i]);

    for(int i = max(k + 1, l - k); i < l; i++) vec1.pb(skim(i));

    r = k, l = 1;
    while(r < n){
        sum -= vec1[l];
        r++;
        sum += vec1[r];
        if(sum >= a and sum <= 2 * a){
            for(int i = l; i <= r; i++) res.pb(i);
            answer(res);
        }
        l++;
    }

    sum = 0;
    vec1.clear();
    for(int i = 0; i < k - 1; i++) sum += vec[i], vec1.pb(i);
    sum += val;
    vec1.pb(l);
    if(sum < 2 * a) answer(vec1);
    impossible();
}



#결과 실행 시간메모리채점기 출력
결과를 불러오는 중입니다…
#결과 실행 시간메모리채점기 출력
결과를 불러오는 중입니다…
#결과 실행 시간메모리채점기 출력
결과를 불러오는 중입니다…
#결과 실행 시간메모리채점기 출력
결과를 불러오는 중입니다…
#결과 실행 시간메모리채점기 출력
결과를 불러오는 중입니다…
#결과 실행 시간메모리채점기 출력
결과를 불러오는 중입니다…
#결과 실행 시간메모리채점기 출력
결과를 불러오는 중입니다…