uva 10054 The Necklace 拼项链 欧拉回路基础应用

昨天做了道水题,今天这题是比较水的应用。

给出n个项链的珠子,珠子的两端有两种颜色,项链上相邻的珠子要颜色匹配,判断能不能拼凑成一天项链。

是挺水的,但是一开始我把整个项链看成一个点,然后用dfs去找,结果超时了。

后来瞄了一眼题解发现把颜色当成点,一个珠子就是一条路,这样就能得到一个无向图了,然后判断欧拉回路即可。

这题默认是珠子为连通的,所以不需要判断连通性。然后判断节点的度数是否为偶数,也就是是否为欧拉回路,如果是的话用深搜输出珠子的顺序。深搜时输出记得得放在递归之后,用逆序输出,不然会出错的,具体看Titanium大神的博客,他介绍的很清楚。(Orz)


代码:

#include <cstdio>
#include <cstring>
const int maxn = 51;
int t, n;
int id[maxn], g[maxn][maxn];

void euler(int u) {
	for (int i = 1; i <= 50; i++) 
		if (g[u][i]) {
			g[u][i]--;
			g[i][u]--;
			euler(i);
			printf("%d %d\n", i, u);
		}
}

int main() {
	scanf("%d", &t);
	int a, b;
	for (int cas = 1; cas <= t; cas++) {
		scanf("%d", &n);
		memset(id, 0, sizeof(id));
		memset(g, 0, sizeof(g));
		for (int i = 0; i < n; i++) {
			scanf("%d%d", &a, &b);
			g[a][b]++;
		   	g[b][a]++;
			id[a]++;
		   	id[b]++;
		}
		int i;
		for (i = 1; i <= 50; i++)
			if (id[i] % 2)
				break;
		if (cas > 1)
			printf("\n");
		printf("Case #%d\n", cas);
		if (i <= 50)
			printf("some beads may be lost\n");
		else
			for (i = 0; i <= 50; i++)
				euler(i);
	}//for
	return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值