TakahiroNakamori

TakahiroNakamori

ナカモリタカヒロ

 
 

Yokan Party(★4)

問題

001 – Yokan Party(★4)
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「AtCoder」。オンラインで毎週開催プログラミングコンテストを開催しています。競技…

記録

解法

コード例

#include <bits/stdc++.h>
using namespace std;
#include <atcoder/all>
using namespace atcoder;
using ll = long long;
using P = pair<int, int>;
#define rep(i, n) for(int i = 0; i < (n); ++i)
// using mint = modint998244353;
// using mint = modint1000000007;
// const int mod = 1000000007;
// const ll INF = 1LL << 62;
// const int INF = 1001001001;

int main() {
  ll N, L, K;
  cin >> N >> L >> K;

  vector<ll> A(N);
  rep(i, N) { cin >> A[i]; }

  int left = -1;
  int right = L + 1;

  while(1 < right - left) {
    int mid = left + (right - left) / 2;
    int cnt = 0;
    int pos = 0;
    rep(i, N) {
      if(mid <= A[i] - pos && mid <= L - A[i]) {
        cnt++;
        pos = A[i];
      }
    }
    if(cnt < K) {
      right = mid;
    } else {
      left = mid;
    }
  }

  cout << left << endl;
  return 0;
}