• <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>

            ACM___________________________

            ______________白白の屋
            posts - 182, comments - 102, trackbacks - 0, articles - 0
            <2010年8月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            常用鏈接

            留言簿(24)

            隨筆分類(332)

            隨筆檔案(182)

            FRIENDS

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            //MiYu原創, 轉帖請注明 : 轉載自 ______________白白の屋

            題目地址:
                    http://acm.hdu.edu.cn/showproblem.php?pid=2094
            題目描述:
             
            Problem Description
            有一群人,打乒乓球比賽,兩兩捉對撕殺,每兩個人之間最多打一場比賽。
            球賽的規則如下:
            如果A打敗了B,B又打敗了C,而A與C之間沒有進行過比賽,那么就認定,A一定能打敗C。
            如果A打敗了B,B又打敗了C,而且,C又打敗了A,那么A、B、C三者都不可能成為冠軍。
            根據這個規則,無需循環較量,或許就能確定冠軍。你的任務就是面對一群比賽選手,在經過了若干場撕殺之后,確定是否已經實際上產生了冠軍。
             

            Input
            輸入含有一些選手群,每群選手都以一個整數n(n
            <1000)開頭,后跟n對選手的比賽結果,比賽結果以一對選手名字(中間隔一空格)表示,前者戰勝后者。如果n為0,則表示輸入結束。
             

            Output
            對于每個選手群,若你判斷出產生了冠軍,則在一行中輸出“Yes”,否則在一行中輸出“No”。
             

            Sample Input
            3
            Alice Bob
            Smith John
            Alice Smith
            5
            a c
            c d
            d e
            b e
            a d
            0
             

            Sample Output
            Yes
            No

            一道很明顯的數據結構題,  用拓撲排序解決.
            當 輸入 A 戰勝 B 時, 讓 B 指向 A, 表示B曾被打敗過.
            最后指向空的就表示沒有人戰勝過他, 如果這樣的人僅
            存在一個,那么明顯,最后的冠軍就是他了.  這里我用到了
            C++ STL 的map set 用來實現 B->A 的映射關系.
            代碼如下 :
            //MiYu原創, 轉帖請注明 : 轉載自 ______________白白の屋

            #include 
            <iostream>
            #include 
            <set>
            #include 
            <map>
            #include 
            <string>
            using namespace std;
            map 
            <stringstring> mp; 
            set <string> st;
            int main ( )
            {
                
            int N;
                
            while ( cin >> N, N )
                {
                    st.clear();
                    mp.clear();
                    
            string s1,s2;
                    
            for ( int i = 0; i != N; ++ i )
                    {
                         cin 
            >> s1 >> s2;
                         st.insert ( s1 );
                         st.insert ( s2 );
                         mp[ s2 ] 
            = s1;
                    }
                    
            set <string>::iterator beg = st.begin();
                    
            int nCount = 0;
                    
            for ( ; beg != st.end (); ++ beg )
                    {
                          
            if ( !mp[ *beg ].length () )
                          {
                             
            ++ nCount;
                          }
                    }
                    puts ( nCount 
            == 1 ? "Yes" : "No" );
                }
                
            return 0;
            }
            色欲综合久久躁天天躁蜜桃| 91精品国产高清91久久久久久| 18岁日韩内射颜射午夜久久成人| 99久久伊人精品综合观看| 久久国产精品99精品国产| 国产国产成人精品久久| 激情伊人五月天久久综合| 久久综合九色综合久99| 久久无码专区国产精品发布| 97久久天天综合色天天综合色hd| 香港aa三级久久三级| 久久婷婷五月综合成人D啪| 久久精品国产日本波多野结衣| 日本精品久久久久中文字幕| 亚洲欧美久久久久9999| 99久久99久久精品国产| 中文成人无码精品久久久不卡| 久久91精品国产91久久麻豆 | 久久天天躁狠狠躁夜夜av浪潮| 久久99精品久久久久久水蜜桃| 无码人妻久久一区二区三区免费| 久久国产乱子精品免费女| 久久久精品无码专区不卡| 青青青国产精品国产精品久久久久| 亚洲欧美国产精品专区久久| 久久se精品一区精品二区| 中文字幕日本人妻久久久免费| 99精品国产99久久久久久97 | 久久久久久精品无码人妻| AV无码久久久久不卡网站下载| 欧美日韩精品久久久久| 理论片午午伦夜理片久久| 成人久久精品一区二区三区| 欧美va久久久噜噜噜久久| 99久久国语露脸精品国产| 欧美va久久久噜噜噜久久| 久久人人爽人人爽人人AV| 久久天天躁狠狠躁夜夜avapp| 久久午夜无码鲁丝片秋霞| 无码人妻久久一区二区三区蜜桃| 久久久久亚洲精品天堂久久久久久|