uva 10308 - Roads in the North(dfs)

题目链接:uva 10308 - Roads in the North


题目大意:给出一个无环无向图,求任意两点间的最大距离。输入空行问该组测试输入结束。


解题思路:输入比较恶心,因为这个WA了一次,这题可以用dfs去做,任意选一个节点作为根节点,然后遍历与它相连的所有点,维护最大值就可以了,因为任意两点可以看成是以父亲节点而相连的。


#include <stdio.h>
#include <string.h>
#include <vector>
#define max(a,b) (a)>(b)?(a):(b)
using namespace std;
const int N = 10005;
const int INF = (1 << 31) - 1;

struct State {
	int id;
	int val;
	State (int x = 0, int c = 0) {
		id = x, val = c;
	}	
};

vector<State> v[N];
int ans, rec[N];

void init() {
	ans = 0;
	for (int i = 0; i < N; i++)
		v[i].clear();
	memset(rec, 0, sizeof(rec));
}

void add(int x, int y, int value) {
	State c(y, value);
	v[x].push_back(c);
}

int dfs(int x) {
	int Max = 0;
	int n = v[x].size();

	rec[x] = 1;
	for (int i = 0; i < n; i++) {
		if (rec[v[x][i].id]) continue;
		int c = dfs(v[x][i].id) + v[x][i].val;

		ans = max(Max + c, ans);
		Max = max(Max, c);
	}
	rec[x] = 0;
	return Max;
}

int main () {
	int a, b, value;
	char str[100];
	while (gets(str)) {
		init();
		while (str[0] != '\0') {
			sscanf(str, "%d%d%d", &a, &b, &value);
			add(a, b, value);
			add(b, a, value);
			if (!gets(str)) break;
		}

		dfs(1);
		printf("%d\n", ans);
	}
	return 0;
}


你可能感兴趣的:(uva 10308 - Roads in the North(dfs))