• <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>
            #include <iostream>
            #include 
            <vector>
            #include 
            <algorithm>

            using namespace std;

            struct Edge
            {
                
            int row;
                
            int column;
                
            int value;

                Edge()
                
            {}

                Edge( 
            int a, int b, int c )
                    :row(a),column(b),value(c)
                
            {}
            }
            ;

            bool operator<( Edge const& Itema, Edge const& Itemb )
            {
                
            return Itema.value> Itemb.value;
            }


            vector
            <Edge> graph;
            int          visite[2001];
            char         ch[2001][8];

            int find( int x )
            {
                
            if ( x!= visite[x] )
                    
            return find( visite[x] );

                
            return x;
            }


            int distance( char str1[8], char str2[8] )
            {
                
            int num= 0;

                
            for ( int i= 0; i< 8++i )
                    
            if ( str1[i]!= str2[i] )
                        num
            ++;

                
            return num;
            }


            int main()
            {
                
            int n;

                
            while ( scanf("%d",&n), n )
                
            {
                    
            for ( int i= 0; i< n; ++i )
                        scanf(
            "%s",ch[i] );

                    graph.reserve ( n
            + 1 );

                    
            for ( int i= 0; i< n; ++i )
                    
            {
                        
            for ( int j= 0; j< i; ++j )
                            graph.push_back (  Edge( j,i,distance( ch[i], ch[j] ) ) );
                
                        visite[i]
            = i;
                    }


                    make_heap( graph.begin (), graph.end () );
                    
            int sum= 0;
                    
            int num= 1;

                    
            while ( num< n )
                    
            {
                        
            int u,v;
                        
            if ( (u= find(graph[0].column))!= (v= find(graph[0].row ) ) )
                        
            {
                            sum
            += graph[0].value;
                            visite[v]
            = u;
                            num
            ++;
                        }


                        pop_heap( graph.begin (), graph.end () );
                        graph.pop_back ();
                    }


                    printf( 
            "The highest possible quality is 1/%d.\n", sum );

                    graph.clear ();
                }


                
            return 0;
            }
            posted on 2008-11-06 12:00 Darren 閱讀(236) 評論(3)  編輯 收藏 引用

            評論:
            # re: Pku 1789 Truck History 2008-11-06 12:42 | infinity
            這題好像就是一個最小生成樹吧!  回復  更多評論
              
            # re: Pku 1789 Truck History 2008-11-06 13:02 | Darren
            @infinity
            這是最小生成樹, 我用的是kruskal算法  回復  更多評論
              
            # re: Pku 1789 Truck History 2008-11-06 14:03 | ******
            我的做法:
            串兩兩比較,匹配他們,統(tǒng)計不同的字符數(shù),然后就產生了一張抽象的權值圖
            然后prim  回復  更多評論
              
            99久久国产精品免费一区二区| 性欧美大战久久久久久久| 伊人久久大香线焦AV综合影院 | 久久久亚洲裙底偷窥综合| A级毛片无码久久精品免费| 欧美精品乱码99久久蜜桃| 国产精品久久久久影视不卡| 亚洲一区二区三区日本久久九| 青青草原综合久久大伊人导航| 久久精品中文字幕大胸| 国产V综合V亚洲欧美久久| 欧美精品一区二区久久| av无码久久久久不卡免费网站 | 国内精品久久九九国产精品| 一97日本道伊人久久综合影院| 久久99国产精品久久久| 久久99精品国产99久久6| 国产欧美一区二区久久| 久久综合九色欧美综合狠狠 | 99久久精品无码一区二区毛片| 青青草国产97免久久费观看| 久久久国产乱子伦精品作者| 久久久亚洲裙底偷窥综合 | 一级a性色生活片久久无少妇一级婬片免费放 | 99久久99久久精品国产片| 中文无码久久精品| 久久婷婷五月综合97色直播| 久久精品aⅴ无码中文字字幕不卡| 久久乐国产精品亚洲综合| 日本精品久久久久中文字幕8 | 日韩AV无码久久一区二区| 亚洲精品无码成人片久久| 久久夜色精品国产噜噜亚洲a| 日韩欧美亚洲综合久久影院d3| 国内精品久久久久久久久电影网| 久久精品国产99久久香蕉| 午夜精品久久久久久久无码| 99久久综合狠狠综合久久| 欧美伊人久久大香线蕉综合69| 青青青青久久精品国产h| 2020最新久久久视精品爱|