最優(yōu)比率生成樹 --- POJ --- 2728

題目鏈接

相關證明在另一篇簡書上

題意就不說了,兩個村莊之間的距離為歐幾里得距離,花費是兩個村莊的海拔高度.
求sigma(cost[i])/sigma(lenth[i]).
思路:
還是二分答案,使得答案不斷接近我們要的那個答案.具體看代碼吧.

#include<cstdio>
#include<cmath>
#include<algorithm>
#include<iostream>
#include<cstring>
#include<stack>
#include<cstdlib>
#define CLR(x) memset(x,0,sizeof(x))
#define ll long long int
#define PI acos(-1.0)
#define db double
#define mod 1000000007
using namespace std;
const int maxn=1e3+5;
const db eps=1e-7;
const db inf=1e9;
int n;
db mapp[maxn][maxn];
db low[maxn];
int vis[maxn];
struct point
{
    int x,y,z;
}s[maxn];

db cal(int m,int n)
{
    return sqrt(1.0 * (s[m].x-s[n].x)*(s[m].x-s[n].x)+1.0 * (s[m].y-s[n].y)*(s[m].y-s[n].y));
}

db prim(int fa,db mid)
{
    db sum=0;
    for(int i=1;i<=n;i++){
        low[i] = abs(s[fa].z-s[i].z)*1.0-mid*mapp[fa][i];   //d[i]數(shù)組.
    }
    CLR(vis);
    //cout << "BUG?" << endl;
    vis[fa]=1;
    for(int i=1;i<n;i++){  //找點肯定只用找n-1個點啊.
        db minn=inf;
        int v=-1;

        for(int j=1;j<=n;j++){
            if(!vis[j] && minn>low[j]){
                v=j;
                minn=low[j];
            }
            //cout << "BUG?" << " " << j << " " << n << endl;
        }

        if(v!=-1){
            sum += minn;
            vis[v]=1;
            for(int j=1;j<=n;j++){
                db tmp=abs(s[v].z-s[j].z)*1.0-mid*mapp[v][j];
                if(!vis[j] && low[j] > tmp)
                    low[j]= tmp;
            }
        }
    }
    //cout << "BUG?" << endl;
    return sum;
}

int main()
{
    while(~scanf("%d",&n) && n){
        for(int i=1;i<=n;i++){
            scanf("%d %d %d",&s[i].x,&s[i].y,&s[i].z);
        }
        CLR(mapp);
        for(int i=1;i<=n;i++){
            for(int j=1;j<=n;j++){
                mapp[i][j] =  cal(i,j);
            }
        }           // 不斷測試,r=100是最好的.
        db l=0,r=100.0,mid;    //二分的范圍自己定,總之越大當然肯定能出答案,但是時間相應也會增長,所以選擇一個合理的范圍是很重的.
        while(r-l>eps){
            mid = (r+l) / 2 ;
            if(prim(1,mid) >= 0 ) l=mid;
            else r=mid;
        }
        printf("%.3f\n",r);
    }

}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

  • 背景 一年多以前我在知乎上答了有關LeetCode的問題, 分享了一些自己做題目的經(jīng)驗。 張土汪:刷leetcod...
    土汪閱讀 12,921評論 0 33
  • 簡介 搜索迷宮(BFS+隊列) 最短路Dijkstra+鄰接矩陣Dijkstra+鏈式前向星+優(yōu)先隊列Bellma...
    染微言閱讀 486評論 0 1
  • G - Cyclic Tour題意:圖中有n個點和m條有向邊現(xiàn)在要將該圖分成若干環(huán),每個環(huán)中至少有兩個點。環(huán)與環(huán)不...
    Gitfan閱讀 846評論 0 1
  • 歸去來兮。 1.1 說明 本篇為《挑戰(zhàn)程序設計競賽(第2版)》[http://www.ituring.com.cn...
    尤汐Yogy閱讀 14,894評論 0 160
  • 1 我已經(jīng)忘了,那天是什么樣的天氣,陰或晴。 腦海里滿滿的都是你要走的劇情,以至于忽略了周圍存在的一切。 一路上我...
    安夏的花花世界閱讀 288評論 0 1

友情鏈接更多精彩內容