# ZeroJudge f315. 低地距離 [f315. 低地距離 (題目連結)](https://zerojudge.tw/ShowProblem?problemid=f315) **BFS做法** <font color="#00CE17">**AC**</font> **(0.7s, 12MB)** ```cpp= #include <bits/stdc++.h> #define int long long using namespace std; const int N = 1e5 + 5; int n, k, st[N << 3]; pair<int, int> p[N]; void build(int pos, int x, int v = 1, int l = 0, int r = k - 1){ if(l == r){ st[v] = x; return; } int m = (l + r) >> 1; if(pos <= m) build(pos, x, v << 1, l, m); else if(pos > m) build(pos, x, v << 1 | 1, m + 1, r); st[v] = st[v << 1] + st[v << 1 | 1]; } int qry(int ql, int qr, int v = 1, int l = 0, int r = k - 1){ if(ql == l && qr == r) return st[v]; int m = (l + r) >> 1; if(qr <= m) return qry(ql, qr, v << 1, l, m); if(ql > m) return qry(ql, qr, v << 1 | 1, m + 1, r); return qry(ql, m, v << 1, l, m) + qry(m + 1, qr, v << 1 | 1, m + 1, r); } signed main(){ ios::sync_with_stdio(false); cin.tie(0); cin>>n; k = n << 1; for(int i=1; i<=n; i++){ p[i].first = -1; p[i].second = -1; } for(int i=0; i<k; i++){ int x; cin>>x; if(p[x].first == -1) p[x].first = i; else p[x].second = i; } int ans = 0; for(int i=1; i<=n; i++){ ans += qry(p[i].first, p[i].second); build(p[i].first, 1); build(p[i].second, 1); } cout<<'\n'<<ans; return 0; } ``` ###### 闕以諾 2022/7/6 ###### tags: `C++` `ZeroJudge` `APCS`