⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 树的优化算法.txt

📁 ACM资料大集合
💻 TXT
字号:
//最大顶点独立集
int max_node_independent(int n,int* pre,int* set){
	int c[MAXN],i,ret=0;
	for (i=0;i<n;i++)
		c[i]=set[i]=0;
	for (i=n-1;i>=0;i--)
		if (!c[i]){
			set[i]=1;
			if (pre[i]!=-1)
				c[pre[i]]=1;
			ret++;
		}
	return ret;
}

//最大边独立集
int max_edge_independent(int n,int* pre,int* set){
	int c[MAXN],i,ret=0;
	for (i=0;i<n;i++)
		c[i]=set[i]=0;
	for (i=n-1;i>=0;i--)
		if (!c[i]&&pre[i]!=-1&&!c[pre[i]]){
			set[i]=1;
			c[pre[i]]=1;
			ret++;
		}
	return ret;
}

//最小顶点覆盖集
int min_node_cover(int n,int* pre,int* set){
	int c[MAXN],i,ret=0;
	for (i=0;i<n;i++)
		c[i]=set[i]=0;
	for (i=n-1;i>=0;i--)
		if (!c[i]&&pre[i]!=-1&&!c[pre[i]]){
			set[i]=1;
			c[pre[i]]=1;
			ret++;
		}
	return ret;
}

//最小顶点支配集
int min_node_dominant(int n,int* pre,int* set){
	int c[MAXN],i,ret=0;
	for (i=0;i<n;i++)
		c[i]=set[i]=0;
	for (i=n-1;i>=0;i--)
		if (!c[i]&&(pre[i]==-1||!set[pre[i]])){
			if (pre[i]!=-1){
				set[pre[i]]=1;
				c[pre[i]]=1;
				if (pre[pre[i]]!=-1)
					c[pre[pre[i]]]=1;
			}
			else
				set[i]=1;
			ret++;
		}
	return ret;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -