本篇內(nèi)容介紹了“PHP樹鏈剖分+函數(shù)式線段樹代碼怎么寫”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
10年積累的成都網(wǎng)站制作、做網(wǎng)站、外貿(mào)營銷網(wǎng)站建設(shè)經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認識你,你也不認識我。但先網(wǎng)站制作后付款的網(wǎng)站建設(shè)流程,更有清澗免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
#include #include #include #include #include #include #include using namespace std; #define MID ( (l+r)>>1 ) #pragma comment(linker, "/STACK:1024000000,1024000000") const int MAXN = 100005; map mp; int itp[MAXN]; struct _edge { int v, next; _edge(int _v=0, int _next=-1):v(_v),next(_next) {} }; struct _seg { int l, r; _seg(int ll=0, int rr=0):l(ll),r(rr) {} } seg[MAXN]; int ns; struct FTree { FTree* ch[2]; int siz; } *root[MAXN], da[MAXN*50], *nf; void build(FTree *& cur, int l, int r) { cur = nf++; cur->siz = 0; if (l == r) return; int m = MID; build(cur->ch[0], l,m); build(cur->ch[1], m+1,r); } int query(FTree* LF, FTree* RT, int L, int R, int l, int r) { if (L <= l && R >= r) return RT->siz-LF->siz; int res = 0; int m = MID; if (L <= m) res += query(LF->ch[0], RT->ch[0], L,R,l,m); if (R > m) res += query(LF->ch[1], RT->ch[1], L,R,m+1,r); return res; } struct node { int head[MAXN], cnt, n; _edge e[MAXN]; int son[MAXN], siz[MAXN], top[MAXN], fa[MAXN], dep[MAXN], pos[MAXN], np; void clear() { cnt = 0; memset(head, -1, sizeof head); np = 0; } void add(int u, int v) { e[cnt] = _edge(v, head[u]); head[u] = cnt++; } void dfs1(int u, int pre) { fa[u] = pre; dep[u] = dep[pre] + 1; siz[u] = 1; son[u] = 0; for (int i = head[u]; ~i; i=e[i].next) { int v = e[i].v; dfs1(v, u); siz[u] += siz[v]; if (siz[son[u]] < siz[v]) son[u] = v; } } void dfs2(int u, int pre) { top[u] = pre; pos[u] = ++np; if (!son[u]) return; dfs2(son[u], pre); for (int i = head[u]; ~i; i = e[i].next) { int v = e[i].v; if ( v!=son[u]) dfs2(v, v); } } void search(int u, int v) { while (top[u] != top[v]) { if (dep[top[u]] > dep[top[v]]) swap(u,v); seg[ns++] = _seg(pos[top[v]], pos[v]); v = fa[top[v]]; } if (dep[u] > dep[v]) swap(u, v); seg[ns++] = _seg(pos[u], pos[v]); } int solve(int u, int v, _seg seg[], int m) { int res = 0; while (top[u] != top[v]) { if (dep[top[u]] > dep[top[v]]) swap(u,v); for (int i = 0; i< ns; ++i) res += query(root[pos[top[v]]-1], root[pos[v]], seg[i].l, seg[i].r, 1, m); v = fa[top[v]]; } if (dep[u] > dep[v]) swap(u, v); for (int i = 0; i< ns; ++i) res += query(root[pos[u]-1], root[pos[v]], seg[i].l, seg[i].r, 1, m); return res; } } NA, NB; void insert(FTree* &cur, FTree* old, int x, int l, int r) { cur = nf++; if (l == r) { cur->siz = old->siz + 1; return; } int m = MID; if (x <= m) { cur->ch[1] = old->ch[1]; insert(cur->ch[0], old->ch[0], x, l, m); } else { cur->ch[0] = old->ch[0]; insert(cur->ch[1], old->ch[1], x, m+1,r); } cur->siz = cur->ch[0]->siz + cur->ch[1]->siz; } void init() { NA.clear(); NB.clear(); mp.clear(); nf = da; memset(root, 0, sizeof root); } int main() { #ifndef ONLINE_JUDGE freopen("in.txt", "r", stdin); #endif int u, q, v, a, b; while (scanf("%d", &NA.n) != EOF) { init(); for (int i = 1; i< NA.n; ++i) { scanf("%d", &u); NA.add(u, i+1); } NA.dfs1(1, 0); NA.dfs2(1, 1); for (int i = 1; i<= NA.n; ++i) scanf("%d", &u), mp[u] = NA.pos[i]; scanf("%d", &NB.n); for (int i = 1; i< NB.n; ++i) { scanf("%d", &u); NB.add(u, i+1); } NB.dfs1(1, 0); NB.dfs2(1, 1); for (int i = 1; i<= NB.n; ++i) { scanf("%d", &u); itp[NB.pos[i]] = mp.count(u)?mp[u]:0; } build(root[0], 1, NA.n); for (int i = 1; i<= NB.n; ++i) { if (itp[i]) insert(root[i], root[i-1], itp[i], 1, NA.n); else root[i] = root[i-1]; } scanf("%d", &q); while (q--) { scanf("%d%d%d%d", &u, &v, &a, &b); ns = 0; NA.search(u, v); printf("%d\n", NB.solve(a, b, seg, NA.n)); } } return 0; }
“PHP樹鏈剖分+函數(shù)式線段樹代碼怎么寫”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!
全國免費咨詢:
業(yè)務(wù)咨詢:028-86922220 / 13518219792
節(jié)假值班:18980820575 / 13518219792
聯(lián)系地址:成都市太升南路288號錦天國際A幢1002號
在線咨詢
微信咨詢
電話咨詢
028-86922220(工作日)
18980820575(7×24)
提交需求
返回頂部