青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Omni Inspirations

problems & programs ~

統計

留言簿

Friends

閱讀排行榜

評論排行榜

SPOJ DISQUERY

題意:
給定一棵N<=100000個點的樹,
有Q<=100000個詢問,求(u,v)路徑上邊權最大值和最小值

做法:
動態樹直接上了。。發覺在這里寫的題是越來越水..
注意要判空節點或者將空節點的最值賦為極限

  1#include <cstdio>
  2#define min(a,b) ((a)<(b)?(a):(b))
  3#define max(a,b) ((a)>(b)?(a):(b))
  4#define n 100005
  5struct Tsplay
  6{
  7    #define Lch(x)    T[x].l
  8    #define Rch(x)    T[x].r
  9    #define Par(x)    T[x].p
 10    #define Max(x)    T[x].max
 11    #define Min(x)    T[x].min
 12    #define Val(x)    T[x].val
 13    #define Root(x)    (Lch(Par(x))!=x&&Rch(Par(x))!=x)
 14    int l,r,p;
 15    int max,min,val;
 16}
    T[n];
 17int vtx[200005],ne[200005],w[200005],L[n],q[n],tot;
 18int N,Q;
 19bool vis[100005];
 20inline void Ins(int u,int v,int ww)
 21{
 22    vtx[++tot]=v;w[tot]=ww;ne[tot]=L[u];L[u]=tot;
 23}

 24inline void BuildTree()
 25{
 26    vis[q[1]=1]=1;
 27    for (int h=1,t=1,u=q[h];h<=t;u=q[++h])
 28    for (int p=L[u],v=vtx[p];p;v=vtx[p=ne[p]])
 29    if (!vis[v])
 30    {
 31        Par(v)=u,Val(v)=w[p];
 32        vis[q[++t]=v]=1;
 33    }

 34}

 35inline void Tupdate(int x)
 36{
 37    Min(x)=Max(x)=Val(x);
 38    if (Lch(x))
 39    {
 40        Min(x)=min(Min(x),Min(Lch(x)));
 41        Max(x)=max(Max(x),Max(Lch(x)));
 42    }

 43    if (Rch(x))
 44    {
 45        Min(x)=min(Min(x),Min(Rch(x)));
 46        Max(x)=max(Max(x),Max(Rch(x)));
 47    }

 48}

 49inline void zig(int x)
 50{
 51    int y=Par(x),z=Par(y);
 52    Lch(y)=Rch(x);
 53    Par(Lch(y))=Rch(x)=y;
 54    if (Lch(z)==y)    Lch(z)=x;
 55    else
 56    if (Rch(z)==y)    Rch(z)=x;
 57    Par(x)=z,Par(y)=x;
 58    Tupdate(y);
 59}

 60inline void zag(int x)
 61{
 62    int y=Par(x),z=Par(y);
 63    Rch(y)=Lch(x);
 64    Par(Rch(y))=Lch(x)=y;
 65    if (Lch(z)==y)    Lch(z)=x;
 66    else
 67    if (Rch(z)==y)    Rch(z)=x;
 68    Par(x)=z,Par(y)=x;
 69    Tupdate(y);
 70}

 71inline void splay(int x)
 72{
 73    for (int y,z;!Root(x);)
 74    {
 75        y=Par(x),z=Par(y);
 76        if (Root(y))
 77            if (Lch(y)==x)    zig(x);
 78            else    zag(x);
 79        else
 80        if (Lch(z)==y)
 81            if (Lch(y)==x)    zig(y),zig(x);
 82            else    zag(x),zig(x);
 83        else
 84            if (Rch(y)==x)    zag(y),zag(x);
 85            else    zig(x),zag(x);
 86    }

 87    Tupdate(x);
 88}

 89inline void Expose(int x)
 90{
 91    for (int u=x,v=0;u;u=Par(u))
 92        splay(u),Rch(u)=v,Tupdate(v=u);
 93}

 94inline void Query(int x,int y)
 95{
 96    Expose(x);
 97    for (int u=y,v=0,vmax,vmin;u;u=Par(u))
 98    {
 99        if (splay(u),!Par(u))
100        {
101            vmax=-(1<<30),vmin=(1<<30);
102            if (v)    vmin=min(vmin,Min(v)),vmax=max(vmax,Max(v));
103            if (Rch(u))    vmin=min(vmin,Min(Rch(u))),vmax=max(vmax,Max(Rch(u)));
104            printf("%d %d\n",vmin,vmax);
105            return;
106        }

107        Rch(u)=v,Tupdate(v=u);
108    }

109}

110int main()
111{
112    int x,y,w;
113    scanf("%d",&N);
114    for (int i=1;i<N;++i)
115        scanf("%d%d%d",&x,&y,&w),Ins(x,y,w),Ins(y,x,w);
116    BuildTree();
117    for (scanf("%d",&Q);Q--;)
118    {
119        scanf("%d%d",&x,&y);
120        Query(x,y);
121    }

122    return 0;
123}

124

posted on 2010-04-15 09:40 jsn1993 閱讀(563) 評論(0)  編輯 收藏 引用 所屬分類: Data Structures

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲精品之草原avav久久| 久久网站热最新地址| 香港久久久电影| 亚洲欧美色婷婷| 亚洲国产mv| 欧美中文字幕在线播放| 欧美在线视频一区| 久久免费高清视频| 女人天堂亚洲aⅴ在线观看| 免费毛片一区二区三区久久久| 久久综合中文| 欧美国产先锋| 国产精品国产成人国产三级| 国产欧美一区二区精品仙草咪| 国产亚洲一区精品| 亚洲激情黄色| 欧美一区91| 亚洲国产99精品国自产| 日韩一级在线观看| 欧美一区日本一区韩国一区| 欧美1区2区视频| 国产精品一区二区三区观看| 亚洲黄色一区二区三区| 午夜精品美女久久久久av福利| 狂野欧美激情性xxxx| 一区二区高清视频在线观看| 久久影视三级福利片| 国产精品国产三级欧美二区| 亚洲福利视频三区| 欧美亚洲一区二区三区| 亚洲精品日韩在线观看| 久久综合狠狠综合久久综合88 | 亚洲女同精品视频| 嫩草国产精品入口| 亚洲欧美日韩网| 欧美激情一区二区三区全黄 | 久久久久成人精品| 国产精品久久久一区麻豆最新章节 | 久久综合五月| 亚洲欧美日韩精品久久亚洲区| 欧美二区乱c少妇| 红桃视频国产精品| 午夜在线精品偷拍| 91久久夜色精品国产网站| 久久久综合免费视频| 国产一区二区观看| 欧美在线影院在线视频| 亚洲一区二区黄| 欧美视频在线观看免费网址| 亚洲激情在线视频| 欧美国产精品va在线观看| 久久久蜜桃一区二区人| 国内精品久久久久久| 久久成人免费网| 亚洲自拍高清| 欧美视频在线观看| ●精品国产综合乱码久久久久| 一区二区三区精品国产| 欧美激情久久久久久| 久久久国产91| 亚洲第一搞黄网站| 欧美大片在线影院| 欧美69wwwcom| 一本色道久久99精品综合| 亚洲人成网站777色婷婷| 欧美国产亚洲视频| 亚洲卡通欧美制服中文| 亚洲乱码国产乱码精品精可以看| 欧美ab在线视频| 亚洲最新中文字幕| 一区二区不卡在线视频 午夜欧美不卡在 | 久久久免费观看视频| 久久国产日韩| 136国产福利精品导航| 男男成人高潮片免费网站| 老司机亚洲精品| 一本色道久久综合亚洲精品按摩 | 欧美高清在线精品一区| 99re66热这里只有精品3直播 | 久久久久一区| 美女尤物久久精品| 亚洲天堂网在线观看| 午夜精品区一区二区三| 狠狠做深爱婷婷久久综合一区| 欧美成va人片在线观看| 欧美色道久久88综合亚洲精品| 欧美在线视频在线播放完整版免费观看| 午夜精品久久久久久久久久久久久 | 亚洲人成在线观看网站高清| 欧美日韩免费在线| 久久精品亚洲一区| 欧美承认网站| 欧美中文字幕在线| 欧美国产精品一区| 久久gogo国模裸体人体| 欧美h视频在线| 欧美亚洲免费| 欧美—级在线免费片| 欧美一区二区三区视频在线 | 亚洲视频免费在线观看| 激情欧美亚洲| 亚洲美女视频网| 亚洲欧洲精品一区二区三区| 国产精品美女主播| 亚洲国产成人在线播放| 国产精品网站视频| 日韩视频免费在线| 在线观看视频一区二区欧美日韩| 亚洲精品一区二区三区四区高清| 国产自产在线视频一区| 亚洲精品视频免费在线观看| 怡红院精品视频在线观看极品| 日韩一区二区免费高清| 亚洲盗摄视频| 久久99伊人| 久久成人在线| 国产精品人人爽人人做我的可爱 | 欧美综合国产| 香蕉成人伊视频在线观看| 欧美日韩理论| 亚洲精品美女在线| 亚洲人成免费| 免费亚洲电影在线| 欧美77777| 在线电影院国产精品| 久久久久99精品国产片| 久久久久久网| 国外成人在线| 久久精品国产96久久久香蕉| 欧美一区影院| 国产日韩欧美电影在线观看| 亚洲在线中文字幕| 欧美亚洲视频在线看网址| 国产精品蜜臀在线观看| 国产精品99久久99久久久二8 | 国产日韩在线看| 欧美亚洲一区二区三区| 久久国产黑丝| 一区在线视频| 麻豆国产精品va在线观看不卡 | 性久久久久久久久久久久| 欧美色欧美亚洲高清在线视频| 亚洲人www| 亚洲字幕一区二区| 国产精品中文字幕在线观看| 亚洲欧美视频在线观看| 久久国产精品网站| 精品粉嫩aⅴ一区二区三区四区| 久久精品午夜| 亚洲国产综合在线看不卡| 亚洲视频电影图片偷拍一区| 国产精品多人| 欧美一区二区三区久久精品茉莉花| 亚洲午夜电影在线观看| 女人天堂亚洲aⅴ在线观看| 亚洲乱码国产乱码精品精可以看 | 蜜月aⅴ免费一区二区三区| 国内精品模特av私拍在线观看| 欧美在线视频一区| 欧美福利视频一区| 99精品国产99久久久久久福利| 欧美三区在线视频| 欧美伊人久久久久久午夜久久久久| 玖玖综合伊人| 一本色道**综合亚洲精品蜜桃冫| 国产精品久久久久久久一区探花 | 亚洲经典三级| 亚洲欧美成人精品| 一色屋精品视频免费看| 欧美激情一区二区三区成人 | 欧美国产一区二区| 亚洲免费视频一区二区| 欧美成人午夜免费视在线看片| 一级日韩一区在线观看| 国产在线不卡视频| 欧美香蕉视频| 久久亚洲色图| 亚洲一区欧美激情| 欧美激情视频一区二区三区不卡| 亚洲欧美综合精品久久成人| 影院欧美亚洲| 国产精品推荐精品| 欧美国产日本韩| 久久久精品动漫| 亚洲无吗在线| 91久久国产综合久久| 久久亚洲精品欧美| 亚洲欧美在线网| 99国产精品国产精品毛片| 激情成人中文字幕| 国产伦精品一区二区三区视频孕妇| 欧美国产精品中文字幕| 久久精品中文字幕一区| 亚洲欧美综合| 在线亚洲伦理| 亚洲免费观看高清完整版在线观看熊 | 亚洲一区中文| 在线视频精品一区| 亚洲日本精品国产第一区| 韩日精品视频|