• <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>
            posts - 74,  comments - 33,  trackbacks - 0
            第一次考慮到輸出路徑點(diǎn)。。。。。
            開(kāi)始的時(shí)候本以為不用拓?fù)洌谝?jiàn)圖的時(shí)候全部建成無(wú)向圖。。。。結(jié)果不言而喻
            部分代碼如下:
            #include<iostream>
            #include
            <stack>
            #include
            <vector>
            #define?MAXN?2100
            using?namespace?std;
            vector
            <int>v[MAXN],nv[MAXN],cont[MAXN];
            int?pre[MAXN],low[MAXN],id[MAXN];
            int?ans[MAXN],dfn[MAXN];
            int?cnt,scnt,n,m,N;
            stack
            <int>ST;
            struct?NODE{
            ????
            int?x,y;????
            }
            arr[MAXN];
            void?Tarjan(int?x){
            ????
            int?t,i;
            ????
            int?min=low[x]=pre[x]=cnt++;
            ????ST.push(x);
            ????
            for(i=0;i<v[x].size();i++){
            ????????t
            =v[x][i];
            ????????
            if(pre[t]==-1)Tarjan(t);
            ????????
            if(low[t]<min)min=low[t];
            ????}

            ????
            if(min<low[x]){
            ????????low[x]
            =min;
            ????????
            return;
            ????}

            ????
            do{
            ????????id[t
            =ST.top()]=scnt;
            ????????low[t]
            =m;ST.pop();
            ????}
            while(t!=x);
            ????scnt
            ++;
            }

            int?SCC(){
            ????scnt
            =cnt=0;
            ????
            while(!ST.empty())ST.pop();
            ????memset(pre,
            0xff,sizeof(pre));
            ????memset(low,
            0,sizeof(low));
            ????
            for(int?i=0;i<m;i++)
            ????????
            if(pre[i]==-1)Tarjan(i);
            ????
            for(int?i=0;i<m;i++)
            ????????cont[id[i]].push_back(i);
            ????
            return?scnt;
            }

            void?DFS(int?k){
            ????dfn[k]
            =cnt++;
            ????
            for(int?i=0;i<nv[k].size();i++){
            ????????
            int?w=nv[k][i];
            ????????
            if(dfn[w]==-1)DFS(w);?
            ????}
            ??
            ????ans[scnt
            ++]=k;?????????????
            }

            void?ColDFS(int?k){
            ????dfn[k]
            =2;
            ????
            for(int?i=0;i<nv[k].size();i++){
            ????????
            int?w=nv[k][i];
            ????????
            if(dfn[w]==-1)ColDFS(w);
            ????}
            ??????????
            }

            void?GetOneAnswer(){
            ????memset(dfn,
            0xff,sizeof(dfn));
            ????
            for(int?i=0;i<m;i++)
            ????????
            for(int?j=0;j<v[i].size();j++){
            ????????????
            int?x=id[i],y=id[v[i][j]];
            ????????????
            if(x!=y)nv[x].push_back(y);????
            ????????}

            ????cnt
            =scnt=0;
            ????
            for(int?i=0;i<N;i++)
            ????????
            if(dfn[i]==-1)DFS(i);
            ????memset(dfn,
            0xff,sizeof(dfn));
            ????
            for(int?i=scnt-1;i>=0;i--)
            ????????
            if(dfn[ans[i]]==-1)?{
            ????????????
            int?a=cont[ans[i]][0],b;?
            ????????????
            if(a<n)b=a+n;
            ????????????
            else?b=a-n;
            ????????????dfn[ans[i]]
            =1;
            ????????????
            if?(dfn[id[b]]==-1)ColDFS(id[b]);?
            ????????}

            }

            void?PRINTF(){
            ????printf(
            "YES\n");
            ????GetOneAnswer();
            ????
            for(int?i=0;i<n;i++){
            ????????
            int?x=arr[i].x,y=arr[i].y;
            ????????
            int?tx=arr[i+n].x,ty=arr[i+n].y;
            ????????
            if(dfn[id[i]]==2)printf("%02d:%02d?%02d:%02d\n",x/60,x%60,y/60,y%60);
            ????????
            else?printf("%02d:%02d?%02d:%02d\n",tx/60,tx%60,ty/60,ty%60);
            ????}
            ????
            }

            void?solve(){
            ????
            int?i=0;
            ????
            for(N=SCC();i<n;i++)
            ????????
            if(id[i]==id[n+i])break;
            ????
            if(i==n)PRINTF();
            ????
            else?printf("NO\n");????
            }
            posted on 2009-06-07 10:39 KNIGHT 閱讀(510) 評(píng)論(0)  編輯 收藏 引用

            只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            <2009年1月>
            28293031123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(8)

            隨筆檔案

            文章檔案

            Friends

            OJ

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久亚洲欧美日本精品| 日韩欧美亚洲综合久久影院Ds| 久久精品亚洲男人的天堂| 国产高潮国产高潮久久久| 色婷婷综合久久久久中文 | 久久亚洲国产精品成人AV秋霞| 天天久久狠狠色综合| 久久青青草原精品国产软件| 99久久精品九九亚洲精品| 日本一区精品久久久久影院| 久久人人超碰精品CAOPOREN| 久久久久这里只有精品 | 亚洲国产另类久久久精品| 97精品伊人久久久大香线蕉| 99久久精品国内| 日本国产精品久久| 久久精品国产福利国产秒| 亚洲精品WWW久久久久久| 国产韩国精品一区二区三区久久| 精品国产综合区久久久久久| 亚洲AV无码久久精品色欲| 久久免费精品一区二区| 亚洲乱码精品久久久久..| 久久一区二区免费播放| 女人香蕉久久**毛片精品| 亚洲а∨天堂久久精品| 日本免费一区二区久久人人澡| 午夜精品久久久久久99热| 久久无码人妻精品一区二区三区| 99久久婷婷免费国产综合精品| 精品久久久久成人码免费动漫| 久久综合九色综合久99| 国产精品免费看久久久香蕉| 久久婷婷国产麻豆91天堂| 亚洲国产另类久久久精品小说 | 久久精品毛片免费观看| 办公室久久精品| 欧美粉嫩小泬久久久久久久 | 国产精品无码久久久久| 久久久精品免费国产四虎| 久久激情亚洲精品无码?V|