제출 #201841

#제출 시각아이디문제언어결과실행 시간메모리
201841anonymousAliens (IOI16_aliens)C++14
100 / 100
156 ms11620 KiB
#include "aliens.h"
#include<vector>
#include<utility>
#include<algorithm>
#define LL long long
#define MAXN 100005
using namespace std;

class CHT {
    vector<pair<pair<LL,LL>, int> > S;
    int pt=0;
public:
    void reset() {
        S.clear();
        pt=0;
    }
    bool bad(LL mq, LL cq, LL num) { //min number of photo
        LL m2=S[S.size()-2].first.first, c2=S[S.size()-2].first.second;
        LL m1=S.back().first.first, c1=S.back().first.second;
        if ((c1-c2)*(m2-mq) != (cq-c2)*(m2-m1)) {
            return((c1-c2)*(m2-mq) > (cq-c2)*(m2-m1));
        }
        return(S.back().second > num);
    }
    void put(LL m, LL c, LL num) {
        while (S.size() > 1 && bad(m,c,num)) {
            S.pop_back();
            pt=min(pt, (int) S.size()-1);
        }
        S.push_back({{m,c},num});
    }
    pair<LL,LL> eval(int l, LL p) {
         return(pair<LL,LL> {S[l].first.first*p+S[l].first.second, S[l].second});
    }
    pair<LL,LL> ask(LL p) { //returns min value & number of photos
        while (pt<S.size()-1 && eval(pt, p) > eval(pt+1, p)) {pt++;}
        return(eval(pt,p));
    }
} CHT;

vector<pair<LL, LL> > Sweep; //r is first l is second
vector<pair<LL,LL> > SS; //sorted stack to get non-dominated points
LL dp[MAXN][2];

pair<LL,LL> slv(LL C) {
    CHT.reset();
    CHT.put(-2*SS[0].second, SS[0].second*SS[0].second,0);
    for (int i=0; i<SS.size(); i++) {
        pair<LL,LL> res=CHT.ask(SS[i].first);
        dp[i+1][0]=res.first + C + SS[i].first*SS[i].first;
        dp[i+1][1]=res.second + 1;
        if (i+1<SS.size()) {
                LL newm=-2*SS[i+1].second;
                LL newc=dp[i+1][0] + SS[i+1].second*SS[i+1].second;
                if (SS[i+1].second < SS[i].first) {newc-=(SS[i+1].second - SS[i].first)*(SS[i+1].second - SS[i].first);}
                CHT.put(newm, newc, dp[i+1][1]);
        }
    }
    return(pair<LL,LL> {dp[SS.size()][0], dp[SS.size()][1]});
}

LL wqs(LL k) {
    LL lo = 0, hi=1LL<<40;
    k=min(k, (LL) SS.size());
    while (lo + 1 != hi) {
        LL mid=(lo+hi)>>1;
        if (slv(mid).second > k) {
            lo=mid;
        } else {
            hi=mid;
        }
    }
    return(slv(hi).first - k*hi);
}

LL take_photos(int n, int m, int k, std::vector<int> r, std::vector<int> c) {
    for (int i=0; i<n; i++) {
        Sweep.push_back({max(r[i],c[i])+1, -min(r[i],c[i])});
    }
    sort(Sweep.begin(), Sweep.end());
    for (auto p: Sweep) {
        p.second=-p.second;
        while (SS.size() && SS.back().second >= p.second) {SS.pop_back();}
        SS.push_back(p);
    }

    return(wqs(k));
}

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

aliens.cpp: In member function 'std::pair<long long int, long long int> CHT::ask(long long int)':
aliens.cpp:36:18: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         while (pt<S.size()-1 && eval(pt, p) > eval(pt+1, p)) {pt++;}
                ~~^~~~~~~~~~~
aliens.cpp: In function 'std::pair<long long int, long long int> slv(long long int)':
aliens.cpp:48:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     for (int i=0; i<SS.size(); i++) {
                   ~^~~~~~~~~~
aliens.cpp:52:16: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         if (i+1<SS.size()) {
             ~~~^~~~~~~~~~
#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...