UVa 10720 - Graph Construction

题目:已知一个无向图的所有顶点的度,问能否构造成一个简单图。

分析:图论。使用Havel定理或者Erdős定理。

            构成图判定:所有点的度数和为偶数(防止溢出可以只判断奇偶);

            构成简单图:

            1.Havel定理:将所有边排序,将度数最大的顶点依次与剩下的顶点连接边(从度数大的开始),

                                      去掉度数最大的顶点后构成子问题,如果出现矛盾则失败,否则成功;

                                    (通过贪心证明);

            2.Erdős定理:

说明:好几道题都卡了很久:-(。

#include <cstdio>  
#include <iostream>  
#include <algorithm>  

using namespace std;

int degrees[10005];

bool cmp(int a, int b) 
{ 
	return a > b; 
}  

int havel_hakimi(int n)
{
	for (int i = 0; i < n; ++ i) {
		sort(degrees+i, degrees+n, cmp);
		for (int j = i+1; j < n && degrees[i]; ++ j) {
			degrees[j] --;
			degrees[i] --;
			if (degrees[j] < 0) {
				return 0; 
			}
		}
		if (degrees[i]) {
			return 0;
		}
	}
	return 1;
}

int main()
{
	int n;
	while (~scanf("%d",&n) && n) {
		int flag = 0;
		for (int i = 0; i < n; ++ i) {
			scanf("%d",°rees[i]);
			if (degrees[i] < 0) {
				flag = 1;
			}
		}
		int sum = 0;
		for (int i = 0; i < n; ++ i) {
			sum += degrees[i];
			sum %= 2;
		}
		if (flag || sum % 2) {
			puts("Not possible");
		}else {
			// Havel-Hakimi
			if (!havel_hakimi(n)) {
				puts("Not possible");
			}else {
				puts("Possible");
			}
		}
	}
	
	return 0;
}
 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: neo4j-d3-graph是一个基于Neo4j和D3.js的图形库,它能够帮助我们将Neo4j图数据库中的数据以可视化的形式呈现出来。 Neo4j是一个高性能的图形数据库,它使用节点和关系来存储和表示数据。而D3.js是一个强大的JavaScript库,用于将数据可视化为各种图形。 neo4j-d3-graph的作用是将这两个功能强大的工具结合起来,使我们能够以图形的形式更好地理解和展现Neo4j数据库中的数据。 使用neo4j-d3-graph,我们可以将Neo4j数据库中的节点和关系转化为D3.js所支持的各种图形,如力导向图、树状图、网络图等。这样,我们就能够直观地观察和分析数据库中的数据结构以及节点之间的关系。 通过neo4j-d3-graph的可视化效果,我们可以更好地发现数据中的模式和趋势,从而帮助我们更好地理解和利用数据库中的信息。 此外,neo4j-d3-graph还提供了一些交互功能,比如节点和关系的悬停效果、点击效果等,使得我们能够与图形进行互动,更加深入地了解和操作数据库中的数据。 综上所述,neo4j-d3-graph是一个强大的图形库,它能够将Neo4j数据库中的数据以可视化的方式展现出来,并提供了交互功能,帮助我们更好地理解和分析数据库中的数据。它为我们的数据分析工作提供了便利和新的视角。 ### 回答2: neo4j-d3-graph是一种用于可视化Neo4j图数据库的工具。Neo4j是一个图数据库,它允许我们以节点和关系的形式存储数据,并通过图形来描述它们之间的关系。然而,对于非技术人员来说,直接查询和理解Neo4j数据库中的数据可能是一个挑战。 这就是neo4j-d3-graph的用武之地。它是基于D3.js的一个开源库,它能够通过一种直观的方式将Neo4j数据库中的数据可视化。它能够创建漂亮而交互式的图表,显示节点和关系,并使用颜色、大小和形状等可视化元素来表达数据的特征。 使用neo4j-d3-graph,我们可以轻松地导入Neo4j数据库中的数据,并以图形方式显示出来。我们可以使用各种布局算法,如力导向布局、层次布局等,来排列节点和关系。我们还可以通过节点和关系的属性来定制节点和关系的外观。 通过这种方式,我们可以更直观地理解和分析Neo4j数据库中的数据。我们可以看到节点之间的关系,找到节点的邻居和路径,并发现潜在的模式和趋势。这对于数据挖掘、社交网络分析、知识图谱等领域非常有用。 总之,neo4j-d3-graph是一个强大而灵活的工具,它使我们能够以可视化的方式探索和理解Neo4j图数据库中的数据。无论是专业人士还是非技术人员,都可以通过这种方式更轻松地使用和分析图形数据。 ### 回答3: neo4j-d3-graph是一个用于可视化Neo4j图数据库的JavaScript库。该库结合了neo4j和d3.js的功能,可以帮助用户以图形的方式更好地理解和分析Neo4j数据库中的数据。 使用neo4j-d3-graph,用户可以创建和展示复杂的图形结构,包括节点和关系。该库提供了大量的配置选项,使用户可以调整节点和关系的样式、颜色和布局。用户还可以通过点击节点或关系,查看相关的详细信息。 除了将数据以可视化的形式展示出来,neo4j-d3-graph还提供了一些交互功能。用户可以通过拖拽节点来重新布局图形,也可以使用搜索功能找到特定的节点或关系。该库还支持导出图形为图片或SVG文件,方便用户在报告或演示中使用。 在开发使用neo4j-d3-graph的过程中,用户需要先通过Neo4j数据库查询出所需的节点和关系数据,并按照一定的格式进行转换。然后,用户需要引入neo4j-d3-graph库,并根据自己的需求进行配置和使用。 总的来说,neo4j-d3-graph是一个强大而灵活的工具,可以帮助用户以可视化的方式更好地理解和分析Neo4j图数据库中的数据。无论是在数据探索、数据可视化还是数据展示方面,该库都提供了丰富的功能和选项供用户使用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值