2#include3#include4#inclu" />

欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

zoj 3602 Count the Trees

系統(tǒng) 1715 0

? http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3602

省賽的C題,方法是hash每個(gè)節(jié)點(diǎn)定義的狀態(tài)。

關(guān)鍵貌似要直接DFS遞歸會(huì)爆棧,所以我手寫(xiě)了一個(gè)棧模擬。

下面還是貼沒(méi)有模擬棧之前的代碼,提交會(huì)sf,不過(guò)看起來(lái)會(huì)好理解很多,模擬部分可以自己去寫(xiě)。

View Code
        
           1
        
         #include<iostream> 


        
           2
        
         #include<cstdio>


        
           3
        
         #include<cstdlib>


        
           4
        
         #include<map>


        
           5
        
         #include<cstring>


        
           6
        
        
          using
        
        
          namespace
        
        
           std;


        
        
           7
        
         typedef 
        
          long
        
        
          long
        
        
           LL;


        
        
           8
        
        
          #define
        
         N 100010


        
           9
        
        
          struct
        
        
           node{


        
        
          10
        
        
          int
        
        
           l,r;


        
        
          11
        
             friend 
        
          bool
        
        
          operator
        
        <(
        
          const
        
         node &x,
        
          const
        
         node &
        
          y){


        
        
          12
        
        
          if
        
        (y.l!=x.l) 
        
          return
        
         y.l<
        
          x.l;


        
        
          13
        
        
          return
        
         y.r<
        
          x.r;


        
        
          14
        
        
              }


        
        
          15
        
         }tree[
        
          2
        
        
          ][N];


        
        
          16
        
        
          int
        
         n,m,cs,num[
        
          2
        
        
          ][N];


        
        
          17
        
         map<node,
        
          int
        
        >
        
           state;


        
        
          18
        
        
          int
        
        
           id(node x){


        
        
          19
        
        
          if
        
        (state.find(x)==
        
          state.end())


        
        
          20
        
                 state[x]=++
        
          cs;


        
        
          21
        
        
          return
        
        
           state[x];


        
        
          22
        
        
          }


        
        
          23
        
        
          int
        
         dfs(
        
          int
        
         u,
        
          int
        
        
           kind){


        
        
          24
        
        
          if
        
        (u==-
        
          1
        
        ) 
        
          return
        
        
          0
        
        
          ;


        
        
          25
        
        
              node temp;


        
        
          26
        
             temp.l=
        
          dfs(tree[kind][u].l,kind);


        
        
          27
        
             temp.r=
        
          dfs(tree[kind][u].r,kind);


        
        
          28
        
        
          int
        
         ans=
        
          id(temp);


        
        
          29
        
             num[kind][ans]++
        
          ;


        
        
          30
        
        
          return
        
        
           ans;


        
        
          31
        
        
          }


        
        
          32
        
        
          int
        
        
           main(){


        
        
          33
        
        
          int
        
        
           T,a,b;


        
        
          34
        
             scanf(
        
          "
        
        
          %d
        
        
          "
        
        ,&
        
          T);


        
        
          35
        
        
          while
        
        (T--
        
          ){


        
        
          36
        
                 scanf(
        
          "
        
        
          %d%d
        
        
          "
        
        ,&n,&
        
          m);


        
        
          37
        
        
          for
        
        (
        
          int
        
         i=
        
          1
        
        ;i<=n;++
        
          i){


        
        
          38
        
                     scanf(
        
          "
        
        
          %d%d
        
        
          "
        
        ,&a,&
        
          b);


        
        
          39
        
                     tree[
        
          0
        
        ][i].l=
        
          a;


        
        
          40
        
                     tree[
        
          0
        
        ][i].r=
        
          b;


        
        
          41
        
        
                  }


        
        
          42
        
        
          for
        
        (
        
          int
        
         i=
        
          1
        
        ;i<=m;++
        
          i){


        
        
          43
        
                     scanf(
        
          "
        
        
          %d%d
        
        
          "
        
        ,&a,&
        
          b);


        
        
          44
        
                     tree[
        
          1
        
        ][i].l=
        
          a;


        
        
          45
        
                     tree[
        
          1
        
        ][i].r=
        
          b;


        
        
          46
        
        
                  }


        
        
          47
        
        
                  state.clear();


        
        
          48
        
                 cs=
        
          0
        
        
          ;


        
        
          49
        
                 memset(num,
        
          0
        
        ,
        
          sizeof
        
        
          (num));


        
        
          50
        
                 dfs(
        
          1
        
        ,
        
          0
        
        
          );


        
        
          51
        
                 dfs(
        
          1
        
        ,
        
          1
        
        
          );


        
        
          52
        
                 LL ans=
        
          0
        
        
          ;


        
        
          53
        
        
          for
        
        (
        
          int
        
         i=
        
          0
        
        ;i<=n+m;++
        
          i)


        
        
          54
        
                     ans+=LL(num[
        
          0
        
        ][i])*LL(num[
        
          1
        
        
          ][i]);


        
        
          55
        
                 printf(
        
          "
        
        
          %lld\n
        
        
          "
        
        
          ,ans);


        
        
          56
        
        
              }


        
        
          57
        
        
          return
        
        
          0
        
        
          ;


        
        
          58
        
         }
      

?

這是模擬棧后的代碼,感覺(jué)自己寫(xiě)的不好...

View Code
        
           1
        
         #include<iostream> 


        
           2
        
         #include<cstdio>


        
           3
        
         #include<cstdlib>


        
           4
        
         #include<map>


        
           5
        
         #include<cstring>


        
           6
        
        
          using
        
        
          namespace
        
        
           std;


        
        
           7
        
         typedef 
        
          long
        
        
          long
        
        
           LL;


        
        
           8
        
        
          #define
        
         N 100010


        
           9
        
        
          struct
        
        
           node{


        
        
          10
        
        
          int
        
        
           l,r;


        
        
          11
        
             friend 
        
          bool
        
        
          operator
        
        <(
        
          const
        
         node &x,
        
          const
        
         node &
        
          y){


        
        
          12
        
        
          if
        
        (y.l!=x.l) 
        
          return
        
         y.l<
        
          x.l;


        
        
          13
        
        
          return
        
         y.r<
        
          x.r;


        
        
          14
        
        
              }


        
        
          15
        
         }tree[
        
          2
        
        
          ][N];


        
        
          16
        
        
          int
        
         n,m,cs,num[
        
          2
        
        ][N<<
        
          1
        
        
          ];


        
        
          17
        
         map<node,
        
          int
        
        >
        
           state;


        
        
          18
        
        
          int
        
        
           id(node x){


        
        
          19
        
        
          if
        
        (state.find(x)==
        
          state.end())


        
        
          20
        
                 state[x]=++
        
          cs;


        
        
          21
        
        
          return
        
        
           state[x];


        
        
          22
        
        
          }


        
        
          23
        
        
          struct
        
        
           stk{


        
        
          24
        
        
          int
        
        
           u,op,st;


        
        
          25
        
        
          }qu[N];


        
        
          26
        
        
          void
        
         dfs(
        
          int
        
         u,
        
          int
        
        
           kind){


        
        
          27
        
        
          int
        
         top=
        
          0
        
        
          ;


        
        
          28
        
             qu[top].u=
        
          u;


        
        
          29
        
             qu[top++].op=
        
          0
        
        
          ;


        
        
          30
        
        
          while
        
        
          (top){


        
        
          31
        
                 stk now=qu[top-
        
          1
        
        
          ];


        
        
          32
        
        
          if
        
        (now.u==-
        
          1
        
        
          ){


        
        
          33
        
                     qu[top-
        
          1
        
        ].st=
        
          0
        
        
          ;


        
        
          34
        
                     top--
        
          ;


        
        
          35
        
        
                  }


        
        
          36
        
        
          else
        
        
          if
        
        (!
        
          now.op){


        
        
          37
        
                     qu[top].u=
        
          tree[kind][now.u].l;


        
        
          38
        
                     qu[top].op=
        
          0
        
        
          ;


        
        
          39
        
                     qu[top-
        
          1
        
        ].op=
        
          1
        
        
          ;


        
        
          40
        
                     top++
        
          ;


        
        
          41
        
        
                  }


        
        
          42
        
        
          else
        
        
          if
        
        (now.op==
        
          1
        
        
          ){


        
        
          43
        
                     qu[top].u=
        
          tree[kind][now.u].r;


        
        
          44
        
                     qu[top].op=
        
          0
        
        
          ;


        
        
          45
        
                     qu[top-
        
          1
        
        ].op=
        
          2
        
        
          ;


        
        
          46
        
                     qu[top-
        
          1
        
        ].st=
        
          qu[top].st;


        
        
          47
        
                     top++
        
          ;


        
        
          48
        
        
                  }


        
        
          49
        
        
          else
        
        
          {


        
        
          50
        
        
                      node temp;


        
        
          51
        
                     temp.l=qu[top-
        
          1
        
        
          ].st;


        
        
          52
        
                     temp.r=
        
          qu[top].st;


        
        
          53
        
        
          int
        
         rig=
        
          id(temp);


        
        
          54
        
                     qu[top-
        
          1
        
        ].st=
        
          rig;


        
        
          55
        
                     num[kind][rig]++
        
          ;


        
        
          56
        
                     top--
        
          ;


        
        
          57
        
        
                  }


        
        
          58
        
        
              }


        
        
          59
        
        
          }


        
        
          60
        
        
          int
        
        
           main(){


        
        
          61
        
        
          int
        
        
           T,a,b;


        
        
          62
        
             scanf(
        
          "
        
        
          %d
        
        
          "
        
        ,&
        
          T);


        
        
          63
        
        
          while
        
        (T--
        
          ){


        
        
          64
        
                 scanf(
        
          "
        
        
          %d%d
        
        
          "
        
        ,&n,&
        
          m);


        
        
          65
        
        
          for
        
        (
        
          int
        
         i=
        
          1
        
        ;i<=n;++
        
          i){


        
        
          66
        
                     scanf(
        
          "
        
        
          %d%d
        
        
          "
        
        ,&a,&
        
          b);


        
        
          67
        
                     tree[
        
          0
        
        ][i].l=
        
          a;


        
        
          68
        
                     tree[
        
          0
        
        ][i].r=
        
          b;


        
        
          69
        
        
                  }


        
        
          70
        
        
          for
        
        (
        
          int
        
         i=
        
          1
        
        ;i<=m;++
        
          i){


        
        
          71
        
                     scanf(
        
          "
        
        
          %d%d
        
        
          "
        
        ,&a,&
        
          b);


        
        
          72
        
                     tree[
        
          1
        
        ][i].l=
        
          a;


        
        
          73
        
                     tree[
        
          1
        
        ][i].r=
        
          b;


        
        
          74
        
        
                  }


        
        
          75
        
        
                  state.clear();


        
        
          76
        
                 cs=
        
          0
        
        
          ;


        
        
          77
        
                 memset(num,
        
          0
        
        ,
        
          sizeof
        
        
          (num));


        
        
          78
        
                 dfs(
        
          1
        
        ,
        
          0
        
        
          );


        
        
          79
        
                 dfs(
        
          1
        
        ,
        
          1
        
        
          );


        
        
          80
        
                 LL ans=
        
          0
        
        
          ;


        
        
          81
        
        
          for
        
        (
        
          int
        
         i=
        
          0
        
        ;i<=cs;++
        
          i)


        
        
          82
        
                     ans+=LL(num[
        
          0
        
        ][i])*LL(num[
        
          1
        
        
          ][i]);


        
        
          83
        
                 printf(
        
          "
        
        
          %lld\n
        
        
          "
        
        
          ,ans);


        
        
          84
        
        
              }


        
        
          85
        
        
          return
        
        
          0
        
        
          ;


        
        
          86
        
         }
      

zoj 3602 Count the Trees


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 亚洲高清在线观看看片 | 欧美777精品久久久久网 | 欧美日皮视频 | 天天看逼 | 美女下面被cao出水 玖玖玖影院 | 亚洲精品乱码久久久久久v 国产高清免费视频 | 午夜色a大片在线观看免费 龙珠z在线观看 | 亚洲国产精品久久久久秋霞蜜臀 | 亚洲毛片网站 | 欧美六九视频 | 成人爽a毛片免费啪啪红桃视频 | 日产乱码卡一卡2卡三卡四麻豆 | 日美女网站 | 国产日韩欧美一区二区 | 国产野花视频天堂视频免费 | 玖玖成人 | 亚洲国产一区二区视频 | 国产精品1区2区3区 亚洲国产aⅴ成人精品无吗 | 天天插天天插天天插 | 国产一区二区久久 | 午夜资源 | 国产亚洲欧美一区 | 久久久无码精品亚洲日韩按摩 | 国产精品久久久一区二区三区 | 午夜伦4480yy私人影院 | 国产成人免费无庶挡视频 | 国产美女精品 | 亚洲精品人成网在线播放影院 | 日日噜噜夜夜狠狠视频buoke | 国产美女高潮 | 97色伦图片97综合影院 | 99久久自偷自偷国产精品不卡 | 免费观看日本a毛片 | 国产亚洲精品影视在线 | 亚洲一区二区三区视频 | 欧美一级片在线播放 | 国产在线视频色综合 | 亚洲精品一区二区三区四区高清 | 狠狠色欧美亚洲狠狠色www | 爱爱视频网站 | 精品国产99 |