• <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 - 21,  comments - 9,  trackbacks - 0
            這個題首先要把輸入的坐標轉化成鄰接矩陣的形式。之后再利用鄰接矩陣使用普里姆算法計算最小生成樹。并對其中的邊進行排序。找出減去S個較大的后最大的那一個。因為較大的那幾個可以用衛星傳輸
            #include<iostream>
            #include<cmath>
            #include<algorithm>
            #include<stdio.h>
            using namespace std;
            typedef struct
            {
             double x;
             double y;
            }point;
            point array[505];
            double len[505][505];
            double kk[505],next[505];
            double re[505];
            int sa,num;
            double dis(point first,point second)
            {
             return sqrt((first.x-second.x)*(first.x-second.x)+(first.y-second.y)*(first.y-second.y));
            }
            void prim(int n)
            {
             int i,j;
              //////////讀入數據完畢。開始構建鄰接矩陣
              for(i=0;i<num;i++)
              {
               for(j=0;j<num;j++)
               {
                len[i][j]=15000000;
               }
              }
              for(i=0;i<num;i++)
              {
               for(j=0;j<num;j++)
               {
                if(i!=j)
                 len[i][j]=dis(array[i],array[j]);
               }
              }
              for(i=0;i<num;i++)
              {
               kk[i]=len[0][i];
               next[i]=0;
              }
              /////////鄰接矩陣構建完畢
              int count=0;i=0;
              while(count<num-1)
              {
               if(next[i]!=-1)
               {
                for(j=0;j<num;j++)
                {
                 if(i!=j&&next[j]!=-1)
                 {
                  if(len[i][j]<kk[j])
                  {
                   kk[j]=len[i][j];
                   next[j]=i;
                  }
                 }
                }
                next[i]=-1;
                double max=999999999;int k;
                for(j=0;j<num;j++)
                {
                 if(kk[j]<max&&next[j]!=-1)
                 {
                  k=j;
                  max=kk[j];
                 }
                }
                re[count]=max;
                i=k;
                count++;
               }
              }
            }
            int main()
            {
             int n;
             cin>>n;
             int i;
             while(n--)
             {
              cin>>sa>>num;
              for( i=0;i<num;i++)
              {
               scanf("%lf%lf",&array[i].x,&array[i].y);
              }
              prim(0);
              sort(re,re+num-1);
              printf("%.2f\n",re[num-1-sa]);
             }
             return 0;
            }
            posted on 2010-08-18 14:39 崔佳星 閱讀(1177) 評論(0)  編輯 收藏 引用
            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            伊人久久大香线蕉综合Av| 久久久久夜夜夜精品国产| 伊人久久大香线焦AV综合影院| 久久久精品人妻一区二区三区蜜桃| 无码人妻精品一区二区三区久久| 久久精品国产99久久久| 久久国产热这里只有精品| 香蕉久久夜色精品升级完成| 久久午夜电影网| 国产激情久久久久久熟女老人| 久久精品一区二区三区不卡| 国产偷久久久精品专区| 久久久久久A亚洲欧洲AV冫| 久久偷看各类wc女厕嘘嘘| 久久精品中文字幕有码| 国产精品18久久久久久vr| 久久这里只有精品首页| 久久99久久无码毛片一区二区| 国内精品伊人久久久久av一坑| 久久久www免费人成精品| 久久久精品视频免费观看| 四虎国产精品免费久久5151| 午夜精品久久久久久99热| 久久国产精品无| 欧美久久久久久午夜精品| 久久av免费天堂小草播放| 欧美激情精品久久久久| 国产91色综合久久免费| 国产精品免费看久久久| 99精品久久精品一区二区| 热re99久久精品国99热| 欧美丰满熟妇BBB久久久| 狠狠色丁香久久婷婷综合_中| 伊人热热久久原色播放www| 久久久久国产亚洲AV麻豆| 国产精品欧美亚洲韩国日本久久 | 狠狠色丁香婷综合久久| 日韩精品久久久久久免费| 激情伊人五月天久久综合| 亚洲成人精品久久| 久久国产三级无码一区二区|