UvaOJ10369 - Arctic Network

 1 /*
 2     The first line of each test case contains 1 <= S <= 100, the number of satellite channels!
 3     注意:S表示一共有多少個衛星,那么就是有 最多有S-1個通道! 然后將最小生成樹中的后邊的 S-1通道去掉就行了! 
 4     思路:最小生成樹中的第 k 個最小邊! 
 5 */
 6 //克魯斯克爾算法.....
 7 #include<iostream>
 8 #include<cstdio>
 9 #include<cstring>
10 #include<algorithm>
11 #include<cmath>
12 using namespace std;
13 
14 double x[800], y[800];
15 
16 struct node{
17    int u, v; 
18    double d;
19 };
20 
21 bool cmp(node a, node b){
22     return a.d < b.d;
23 }
24 
25 int f[505];
26 
27 node nd[150000];
28 double ret[505];
29 
30 int getFather(int x){
31    return x==f[x] ? x : f[x]=getFather(f[x]);
32 }
33 
34 bool Union(int a, int b){
35    int fa=getFather(a), fb=getFather(b);
36    if(fa!=fb){
37        f[fa]=fb;
38        return true;
39    }
40    return false;
41 }
42 
43 int main(){
44    int n, m;
45    int t;
46    scanf("%d", &t);
47    while(t--){
48           scanf("%d%d", &m, &n);
49        for(int i=1; i<=n; ++i){
50           scanf("%lf%lf", &x[i], &y[i]);
51           f[i]=i;
52        }
53        int cnt=0;
54        for(int i=1; i<n; ++i)
55           for(int j=i+1; j<=n; ++j){
56               nd[cnt].u=i;
57               nd[cnt].v=j;
58               nd[cnt++].d=sqrt( (x[i]-x[j])*(x[i]-x[j]) + (y[i]-y[j])*(y[i]-y[j]));
59           }
60        sort(nd, nd+cnt, cmp);
61        int cc=0;
62        for(int i=0; i<cnt; ++i)
63           if(Union(nd[i].u, nd[i].v))
64              ret[cc++]=nd[i].d;
65         for(int i=0; i<cc; ++i)
66            cout<<ret[i]<<"fdsf"<<endl;
67        printf("%.2lf\n", ret[n-m-1]);
68    }
69    return 0;
70 }   

 1 //prim算法.......
 2 #include<iostream>
 3 #include<cstdio>
 4 #include<cstring>
 5 #include<algorithm>
 6 #include<cmath>
 7 using namespace std;
 8 const double INF = 0x3f3f3f3f*1.0;
 9 double x[800], y[800];
10 
11 int n, m;
12 double map[505][505];
13 int vis[505];
14 
15 double ret[505];
16 
17 void prim(){
18     memset(vis, 0, sizeof(vis));
19     vis[1]=1;
20     for(int i=2; i<=n; ++i)
21        ret[i]=INF;
22     int root=1, p;
23     for(int i=1; i<n; ++i){
24         double minLen=INF; 
25         for(int j=2; j<=n; ++j){
26            if(!vis[j] && ret[j]>map[root][j])
27               ret[j]=map[root][j];
28            if(!vis[j] && minLen>ret[j]){
29               minLen=ret[j];
30               p=j; 
31            }
32         }
33         root=p;
34         vis[root]=1;
35     }
36 }
37 
38 int main(){
39    
40    int t;
41    scanf("%d", &t);
42    while(t--){
43           scanf("%d%d", &m, &n);
44        for(int i=1; i<=n; ++i)
45           scanf("%lf%lf", &x[i], &y[i]);
46        for(int i=1; i<n; ++i)
47           for(int j=i+1; j<=n; ++j)
48              map[i][j]=map[j][i]=sqrt( (x[i]-x[j])*(x[i]-x[j]) + (y[i]-y[j])*(y[i]-y[j]));
49 
50        prim();
51        sort(ret, ret+n+1);
52        
53        printf("%.2lf\n", ret[n-m+1]);
54    }
55    return 0;
56 }

?

?

轉載于:https://www.cnblogs.com/hujunzheng/p/3899428.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531783.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531783.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531783.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

獲取list泛型_泛型

泛型什么是泛型&#xff1f;為什么使用泛型&#xff1f;泛型的出現意味著編寫的代碼可以被不同類型的對象所重用&#xff0c;提升了代碼的重用性。泛型的本質是參數化類型&#xff0c;即將所需操作的數據類型設置為一個參數。 舉個實際中的栗子&#xff1a;我們需要設計一個柜子…

w10計算機字體怎么設置在哪里設置,如何設置修改win10系統電腦的顯示字體

如何設置修改win10系統電腦的顯示字體騰訊視頻/愛奇藝/優酷/外賣 充值4折起今天給大家介紹一下如何設置修改win10系統電腦的顯示字體的具體操作步驟。1. 首先鼠標左鍵開始&#xff0c;然后在菜單下的左下角選擇設置圖標。2. 進入Windows 設置后&#xff0c;單擊個性化。3. 接著…

uva 10801 - Lift Hopping(最短路Dijkstra)

1 /*2 題目大意&#xff1a;3 就是一幢大廈中有0&#xff5e;99的樓層, 然后有1&#xff5e;5個電梯&#xff01;每個電梯有一定的上升或下降速度和樓層的停止的位置&#xff01;4 問從第0層樓到第k層最少經過多長時間到達&#xff01;5 6 思路&#x…

powerdesigner mysql 自增主鍵_PowerDesigner Mysql 主鍵自增、初始值、字符集

自增在你所要設為自增型的鍵上(比如你的id)雙擊&#xff0c;彈出一個Column Properties對話框&#xff0c;右下角有一個Identify的選擇框&#xff0c;選中它OK&#xff0c;就可以了。 再去查看Preview&#xff0c;就能看到AUTO_INCREMENT。起始值默認自增字段從1開始, 如果需要…

計算機設置從u盤啟動怎么辦,電腦設置從u盤啟動盤啟動出現藍屏該怎么解決?

電腦設置從u盤啟動藍屏怎么辦?我們在電腦遇到系統等問題時&#xff0c;經常會選擇使用u盤重裝系統&#xff0c;這種重裝方式可以說是目前最便捷實用的了。但是最近又有用戶反映將U盤設置為第一啟動項后&#xff0c;電腦沒辦法從u盤啟動&#xff0c;出現了藍屏的情況&#xff0…

NYOJ 99單詞拼接(有向圖的歐拉(回)路)

1 /*2 NYOJ 99單詞拼接:3 思路&#xff1a;歐拉回路或者歐拉路的搜索&#xff01;4 注意&#xff1a;是有向圖的&#xff01;不要當成無向圖&#xff0c;否則在在搜索之前的判斷中因為判斷有無導致不必要的搜索&#xff0c;以致TLE!5 有向圖的歐拉路&#xff1a;ab…

mysql 過程和函數_MySQL:存儲過程和函數

變量系統變量變量由系統提供&#xff0c;不是用戶自定義的&#xff0c;屬于服務器層面全局變量會話變量# 如果是全局級別&#xff0c;則需要加global&#xff0c;如果是會話級別&#xff0c;則需要加session&#xff0c;如果不寫&#xff0c;則默認是會話# 查看全局變量SHOW GL…

python修改服務器ip,[python+Bat]讀表修改機房IP

[Shell] 純文本查看 復制代碼拷貝一下腳本到.bat文件&#xff0c;雙擊運行即可&#xff0c;有交互式提示輸入新的計算機名 ECHO OFFcolor 0AECHO ----------------------------------------------------------------------------ECHO.ECHO 版權所有 copyright of ECHO.ECHO ~~~…

hdu 1811Rank of Tetris (并查集 + 拓撲排序)

1 /*2 題意&#xff1a;這些信息可能有三種情況&#xff0c;分別是"A > B","A B","A < B"&#xff0c;分別表示A的Rating高于B,等于B,小于B。3 4 現在Lele并不是讓你來幫他制作這個高手榜&#xff0c;他只是想知道&#xff0c;根據這…

ambari mysql jar_從零開始安裝 Ambari (3) -- 安裝 Ambari

1. 安裝yum -y install ambari-server2. ambari server 需要一個數據庫存儲元數據&#xff0c;默認使用的 Postgres 數據庫。默認的用戶名和密碼是&#xff1a; ambari/bigdata 。但是一般情況下&#xff0c;后面還要安裝 hive 和 Ranger&#xff0c;也需要一個存元數據的數據庫…

服務器2012系統在dos卸載,Windows系統下徹底刪除Windows.old 文件夾的方法

系統是直接硬盤安裝的&#xff0c;導致c盤產生了舊系統的文件夾Windows.old&#xff0c;占用很大的磁盤空間&#xff0c;刪也刪不掉&#xff0c;咋辦&#xff1f;不要緊&#xff0c;下面大神來教你神操作&#xff01;&#xff01;&#xff01;1、打開“計算機”&#xff0c;選擇…

hdu3635 Dragon Balls(帶權并查集)

1 /*2 題意&#xff1a;有N個城市&#xff0c; 每一個城市都有一個龍珠&#xff08;編號與城市的編號相同&#xff09;&#xff0c;有兩個操作3 T A ,B 將標號為A龍珠所在城市的所有的龍珠移動到B龍珠所在城市中&#xff01; 4 5 思路&#xff1a;并查集 &#xff…

backupexec mysql_MySQL備份可能遇到的坑

MySQL備份工具&#xff0c;支持各種參數選項&#xff0c;使用不同的選項極有可能影響備份處理過程。本文使用我們常規認為合理的備份參數&#xff0c;測試/驗證是否存在容易忽視的坑# 常規備份參數# mysqldumpshell> mysqldump --single-transaction --master-data2 -B repl…

win10虛擬機服務器錯誤怎么解決方法,虛擬機下安裝win10系統后出現升級報錯故障的解決方法【圖文】...

現在的win10還是很挑系統的&#xff0c;兼容性有待進一步增強。有些在虛擬機環境下安裝了win10的小伙伴&#xff0c;升級是很可能報以下錯誤的&#xff0c;升級你的ESX版本吧&#xff0c;5.5以下升級win10基本都是沒戲的。VM workstation11以上是明確支持win10。不能升級win10怎…

hdu1962Corporative Network帶權回路

1 /*2 有N個企業&#xff0c;每個企業想要實現通信&#xff0c;要用線路來連接&#xff0c;線路的長度為abs(a-b)%1000;3 如果企業a 鏈接到了企業b 那么b就是the center of the serving!4 然后有兩種操作&#xff1a;5 E a &#xff1a; 輸出企業a到serving ce…

mysql客戶端修改sqlmode_MySQL修改sql_mode

一 ERR 1067引發的血案今天在Navicat中運行sql語句創建數據表出現了錯誤Err 1067。而這條語句在有些同事的mysql上是正確的&#xff0c;但是在有些人那里就報錯。QQ截圖20170811143551.png原因竟然是timestamp的默認值不正確。查閱資料得知&#xff0c;mysql5.7版本中有了一個S…

零基礎mysql項目實例_MySQL-零基礎開發

1.終端下連接mysql服務mysql -uroot -p回車后輸入設定的密碼即可。進去后每條命令結尾要帶分號&#xff1b;退出命令exit單行注釋有兩種&#xff1a;#  或 --空格。多行注釋/*  */2.基本命令集合針對數據庫&#xff1a;use sys;  show databases;查看當前操作的數據庫&a…

hdu2066一個人的旅行(多源點多匯點的最短路徑問題)

&#xff0f;&#xff0a;思路&#xff1a;多源點&#xff0c;多會點的最短路徑&#xff01;將最小號&#xff0d;&#xff11;的節點但最源點&#xff0c;將最大號&#xff0b;&#xff11;的點當作匯點&#xff01;將問題轉變成從一個源點到一個匯點的最短路徑的問題&#xf…

php設置mysql 編碼_php怎么設置mysql編碼?

在php中&#xff0c;可以使用mysql_query()函數來設置mysql編碼&#xff0c;語法“mysql_query(SET NAMES 編碼方式);”&#xff1b;mysql_query()函數需要放置在mysql_connect()語句之后。在php中&#xff0c;可以使用mysql_query()函數來設置mysql編碼。在PHP連接數據庫的時候…

nyoj 925 國王的煩惱(最小生成樹)

1 /*2 題意&#xff1a;N個城市中每兩個城市有多條路徑連接&#xff0c;可是因為路徑存在的天數是有限的&#xff01;以為某條路經不存在了3 導致N個城市不能連通了&#xff0c;那么村名們就會抗議&#xff01;問一共會有多少次抗議&#xff01;4 5 思路&#…