程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> hdu 1162 Eddy's picture(基礎最小生成樹)

hdu 1162 Eddy's picture(基礎最小生成樹)

編輯:C++入門知識

題目:

連接:點擊打開鏈接

題意:

n個點,是每個點相互連通(直接間接),求最短距離。

思路:

prim()最小生成樹。把點的距離存在map中。

代碼:

#include
#include
#include
#include
using namespace std;
#define MAXN 110
#define MAX 100000000

struct node{
    double x,y;
}p[MAXN];

double map[MAXN][MAXN];
double low[MAXN];
int vis[MAXN];
int n;

void prim()
{
    int pos;
    double minn;
    double result = 0;
    memset(vis,0,sizeof(vis));
    pos = 1;
    vis[pos] = 1;
    for(int i=1; i<=n; i++)
    {
        if(i != pos)
            low[i] = map[pos][i];
    }
    for(int i=1; i low[j])
            {
                minn = low[j];
                pos = j;
            }
        }
        result += minn;
        vis[pos] = 1;
        for(int j=1; j<=n; j++)
        {
            if(!vis[j] && map[pos][j] < low[j])
                low[j] = map[pos][j];
        }
    }
    printf("%.2lf\n",result);
}

int main()
{
    //freopen("input.txt","r",stdin);
    while(scanf("%d",&n) != EOF)
    {
        for(int i=1; i<=n; i++)
            scanf("%lf%lf",&p[i].x,&p[i].y);
        for(int i=1; i<=n; i++)
        {
            for(int j=1; j<=n; j++)
                map[i][j] = sqrt((p[i].x-p[j].x)*(p[i].x-p[j].x) + (p[i].y-p[j].y)*(p[i].y-p[j].y));
        }
        prim();
    }
    return 0;
}

-----------------------------------------------------------------------------------

戰斗,永不停歇~~~~~~~~~~~~~~~~~~~~~

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved