首页 > 其他分享 >CF566E Restoring Map

CF566E Restoring Map

时间:2022-12-14 22:14:57浏览次数:51  
标签:Map CF566E int 叶子 Restoring include 节点 1001

链接:https://www.luogu.com.cn/problem/CF566E

题目描述:有一个\(n\)个节点的树,你得到了\(n\)条关于每个点信息,每条信息记录了距离某一个点小于等于\(2\)的所有点,但你不知道每条信息具体是哪个点的,你需要构造一棵满足这些信息的树。

数据范围:\(n<=1000\)

题解:对于这个题,我们可以发现一些性质:

性质\(1\):若对于非叶节点\(x,y\),若这些信息之间的交有\({x,y}\),则\(x,y\)之间有边。(由此也可判\(x,y\)是否是叶子节点)

证明:对\(x\)扩展不为\(y\)的点\(u\),对\(y\)扩展不为\(x\)的点\(v\),则画图可知\(u,v\)点集交为\({x,y}\),而若它们间无边,那么它们不能同时分配到一个大小为\(2\)的点集中。

性质\(2\):叶子节点的集合是包含它的最小点集。

证明:考虑叶子节点的父亲节点的父亲节点\(x\),所有叶子走两步能到的节点都能被\(x\)所走到,而当\(x\)的走到的点与叶子节点相同,则它们刚好"对称",随便放都可以。

性质\(3\):当非叶节点个数\(>=2\)时,叶子节点集合的非叶子节点之间居中的那个点是它的父亲节点。

证明:首先\(dep\)居中的是合法的,那么需证明有且仅有一个,而当有两个合法的点时,有一个点的集合会包含与它距离\(3\)的点,则矛盾。

当非叶节点个数为\(0,2\)时要特判,其余情况可用上述性质构造方案

#include<iostream>
#include<cstdio>
#include<bitset>
using namespace std;
int read()
{
  char c=0;
  int sum=0;
  while (c<'0'||c>'9')
    c=getchar();
  while ('0'<=c&&c<='9')
    sum=sum*10+c-'0',c=getchar();
  return sum;
}
int n,cnt,x;
bitset<1000>p[1001];
bitset<1000>T;
bitset<1000>R[1001];
bitset<1000>F[1001];
bool S[1001][1001];
int fa[1001];
bool vis[1001],used[1001];
int color[1001],rt[1001];
int main()
{
  int t;
  n=read();
  for (int i=1;i<=n;++i)
    {
      t=read(),cnt+=t;
      while (t--)
	x=read(),p[i][x]=1;
    }
  if (cnt==n*n)
    {
      for (int i=2;i<=n;++i)
	printf("%d %d\n",1,i);
      return 0;
    }
  int st,ed,len=0;
  for (int i=1;i<=n;++i)
    for (int j=i+1;j<=n;++j)
      if ((p[i]&p[j]).count()==2)
	T=p[i]&p[j],st=T._Find_first(),ed=T._Find_next(st),F[st][ed]=1,F[ed][st]=1,used[st]=1,used[ed]=1;
  for (int i=1;i<=n;++i)
    if (used[i])
      F[i][i]=1;
  for (int i=1;i<=n;++i)
    for (int j=i+1;j<=n;++j)
      if (used[i]&&used[j]&&F[i][j])
	printf("%d %d\n",i,j),len++;
  int res,miner;
  for (int i=1;i<=n;++i)
    if (!used[i])
      {
	res=1e9,miner=-1;
	for (int j=1;j<=n;++j)
	  if (p[j][i]&&p[j].count()<res)
	    res=p[j].count(),miner=j;
	R[i]=p[miner];
	if (len!=1)
	  {
	    for (int j=1;j<=n;++j)
	      if (!used[j])
		R[i][j]=0;
	  }
      }
  if (len==1)
    {
      for (int i=1;i<=n;++i)
	for (int j=1;j<=i;++j)
	    if (!used[i]&&!used[j]&&R[i][j])
	      {
		S[j][i]=1;
		break;
	      }
      for (int i=1;i<=n;++i)
	if (!used[i]&&S[i][i])
	  {
	    if (st)
	      {
		for (int j=1;j<=n;++j)
		  if (S[i][j])
		    printf("%d %d\n",st,j);
		st=0;
	      }
	    else
	      {
		for (int j=1;j<=n;++j)
		  if (S[i][j])
		    printf("%d %d\n",ed,j);
	      }
	  }
      return 0;
    }
  for (int i=1;i<=n;++i)
    {
      for (int j=1;j<=n;++j)
	if (!used[i]&&used[j]&&F[j]==R[i])
	  printf("%d %d\n",i,j);
    }
  return 0;
}

标签:Map,CF566E,int,叶子,Restoring,include,节点,1001
From: https://www.cnblogs.com/zhouhuanyi/p/16983766.html

相关文章

  • Go语言基础之map
    Go语言中提供的映射关系容器为map,其内部使用散列表(hash)实现。mapmap是一种无序的基于key-value的数据结构,Go语言中的map是引用类型,必须初始化才能使用。map定义......
  • HashMap原理解析
    1.HashMap的数据结构数据结构中有数组和链表来实现对数据的存储,但这两者基本上是两个极端。时间复杂度小,为O(1);数组的特点是:寻址容易,插入和删除困难;链表链表存储区间离散......
  • 对于Servlet原理以及Mapping的五种映射和404页面的详解
    一.Servlet原理1,浏览器向web容器发送Http请求,我们这里用的web容器为tomcat。2.我们在Servlet里的protectedvoiddoGet(HttpServletRequestreq,HttpServletResponsere......
  • mybatis-plus的BaseMapper
    顾名思义,BaseMapper就是基础的mapper,我们可以通过继承BaseMapper来实现基础的CRUD功能而无需再写单独的xml文件,这个对于SQL不复杂的场景和表来说非常的友好。基本的使用......
  • mybatis的resultType和resultMap
    resultType作为返回值可以是一个基本类型也可以是实体类对象也就是说是一个具体的类如果我们要返回的对象不是一个具体的类假如我们的实体类的属性和数据库的字段不一......
  • mybatis的mapper映射文件
    mybatis的mapper映射文件MyBatis的真正强大在于它的语句映射,这是它的魔力所在。由于它的异常强大,映射器的XML文件就显得相对简单。如果拿它跟具有相同功能的JDBC代码......
  • Ireport实现接收List<Map>参数并展示出来
    首先:在你的报表中接收java传过来的字段他们统一放置在parameter中,sql查询出的字段统一放置在fields中。那么如下我的parameters中有一个equips的字段。它是collection类型......
  • 一个由resultMap引发的错误以及后果
       废话不多说,上图,那么他会引起什么错误呢?    我们可以看到如图,报错找不到实体类,但是我写的是   这个类为什么会说我的实体类找不到呢,debug......
  • 【Python内置函数map和zip+上下文管理器及其实现原理】
    一、map作用map:自动将可迭代对象遍历,把遍历出来的数据,当成参数传入map第一个接口的函数中,将函数执行的结果,放到一个迭代器中进行返回语法map(function,iterable,...)第......
  • RequestMappingHandlerMapping请求地址映射的初始化流程!
    之前的文章里,介绍了DispatcherSerlvet处理请求的流程。其中一个核心的步骤是:请求地址映射,即根据request获取对应的HandlerExcecutionChain。为了后续的请求地址映射,在项......