放牧代码和思想
专注自然语言处理、机器学习算法
    愛しさ 優しさ すべて投げ出してもいい

POJ 2377 Bad Cowtractors 题解 《挑战程序设计竞赛》

POJ 2377 Bad Cowtractors

坏奶牛:为了破坏农夫约翰的光纤计划,奶牛决定骗丫拉一条最长的网络。

2.5 它们其实都是“图”

最小生成树

其实是所谓的最大生成树,只要按花费从大到小加入树就行了。我看kruskal改一个符号就行了于是就它了,另外需要判断一下是否有悬孤节点,总之又是一道水题。最近在看斯坦福大学的NLP open course,感觉特赞,顺便还能考个托福。

#ifndef ONLINE_JUDGE
#pragma warning(disable : 4996)
#endif
#include <iostream>
#include <algorithm>
using namespace std;

#define MAX_E 20000 + 16

// 并查集相关数据与算法
#define MAX_N 1000 + 16
int parent[MAX_N];
int height[MAX_N];

void init(const int& n)
{
	for (int i = 0; i < n; ++i)
	{
		parent[i] = i;
		height[i] = 0;
	}
}

int find(const int& x)
{
	if (parent[x] == x)
	{
		return x;
	}
	else
	{
		return parent[x] = find(parent[x]);
	}
}

void unite(int x, int y)
{
	x = find(x);
	y = find(y);
	if (x == y)
	{
		return;
	}

	if (height[x] < height[y])
	{
		parent[x] = y;
	}
	else
	{
		parent[y] = x;
		if (height[x] == height[y])
		{
			++height[x];
		}
	}
}

bool same(const int& x, const int& y)
{
	return find(x) == find(y);
}
// End Of 并查集

struct edge
{
	int u, v, cost;
	edge(int u = 0, int v = 0, int cost = 0) : u(u), v(v), cost(cost) {}
	bool operator < (const edge & e2) const
	{
		return cost > e2.cost;
	}
};
edge es[MAX_E];
int V, E;
int in_tree;	// 在树中的节点个数
int kruskal()
{
	sort(es, es + E);	// 按照权值从小到大排序
	init(V);
	int res = 0;
	in_tree = 1;
	for (int i = 0; i < E && in_tree <= V; ++i)
	{
		edge e = es[i];
		if (!same(e.u, e.v))
		{
			unite(e.u, e.v);
			res += e.cost;
			++in_tree;
		}
	}

	return res;
}

///////////////////////////SubMain//////////////////////////////////
int main(int argc, char *argv[])
{
#ifndef ONLINE_JUDGE
	freopen("in.txt", "r", stdin);
	freopen("out.txt", "w", stdout);
#endif
	cin >> V >> E;
	for (int i = 0; i < E; ++i)
	{
		cin >> es[i].u >> es[i].v >> es[i].cost;
		--es[i].u; --es[i].v;
	}

	int ans = kruskal();
	if (in_tree < V)
	{
		ans = -1;
	}
	cout << ans << endl;

#ifndef ONLINE_JUDGE
	fclose(stdin);
	fclose(stdout);
	system("out.txt");
#endif
	return 0;
}
///////////////////////////End Sub//////////////////////////////////

知识共享许可协议 知识共享署名-非商业性使用-相同方式共享码农场 » POJ 2377 Bad Cowtractors 题解 《挑战程序设计竞赛》

评论 2

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
  1. #1

    楼主prim算法怎么解决非联通图啊,if(mincost [v] ==INF)
    {
    res=1;
    return res;
    }这样不可以吗

    qingxi曾10年前 (2015-03-13)回复
    • 悬孤节点不在邻接表中,根本无法触发这个条件

      hankcs10年前 (2015-03-13)回复

我的作品

HanLP自然语言处理包《自然语言处理入门》