제출 #1359483

#제출 시각아이디문제언어결과실행 시간메모리
1359483huseyncafarliBitaro the Brave 2 (JOI25_ho_t2)C++20
22 / 100
494 ms70892 KiB
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define int ll

const int MAXN = 1e6 + 5;
const int inf = (int)2e9 + 5;
const int infll = (int)4e18 + 5;
const int mod = (int)1e9 + 7;

int md;

struct SegmentTree {
  int n;
  vector<int> tree;
  vector<int> lazy;
  SegmentTree(int n) {
    this->n = n;
    tree.assign(4*n, 0);
    lazy.assign(4*n, 0);
  }
  void relax(int v, int l, int r) {
    if(lazy[v] == 0) return;
    tree[v] += lazy[v];
    if(l != r) {
      lazy[v<<1] += lazy[v];
      lazy[v<<1|1] += lazy[v];
    }
    lazy[v] = 0;
  }
  void update(int v, int l, int r, int a, int b, int val) {
    relax(v, l, r);
    if(r < a or l > b) return;
    if(l >= a and r <= b) {
      lazy[v] += val;
      relax(v, l, r);
      return;
    }
    int mid = (l + r) >> 1;
    update(v<<1, l, mid, a, b, val);
    update(v<<1|1, mid + 1, r, a, b, val);
    tree[v] = max(tree[v<<1], tree[v<<1|1]);
  }
  int query(int v, int l, int r, int ql, int qr) {
    relax(v, l, r);
    if(r < ql or l > qr) return 0;
    if(l >= ql and r <= qr) return tree[v];
    int mid = (l + r) >> 1;
    return max(query(v<<1, l, mid, ql, qr), query(v<<1|1, mid + 1, r, ql, qr));
  }
};


void solve(){
  int n;
  cin >> n;
  md = n;
  vector<int> a(n + 1), b(n + 1);
  SegmentTree st(2*n + 5);
  for(int i = 1; i <= n; i++) {
    cin >> a[i];
    st.update(1, 1, 2*n, i, i, a[i] - i);
    st.update(1,1, 2*n, i + n, i + n, a[i] - i - n);
  }
  for(int i = 1; i <= n; i++) {
    cin >> b[i];
  }
  int mn = inf;
  for(int i = 1; i <= n; i++) {
    int x;
    st.update(1,1,2*n,i,i+n-1, i);
    x = st.query(1,1,2*n,i,i+n-1);
    mn = min(x, mn);
    st.update(1,1,2*n,i,i+n-1, -i);
  }
  cout << mn << endl;
}

signed main() {
  ios::sync_with_stdio(0);
  cin.tie(0);
  int t = 1;
  //cin >> t;
  while(t--)
    solve();
  return 0;
}

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