题目

给出一个 $n$,判断是否存在 $n$ 个顶点的自补图,如果存在,输出边和映射。

分析

一个无向图若同构于它的补图,则称该图为自补图

定理:一个自补图一定存在 $4k$ 或 $4k+1$ 个顶点.

证:

原图的边数+补图的边数=完全图的边数=n(n-1)/2

由于原图与补图同构,所以边数相等,

所以,原图的边数=n(n-1)/4,

边数肯定为整数,所以 4|n 或者 4|(n+1).

现在的问题是如何构造呢?

先考虑 $n=4k$,将其分成两半,

一半连接成完全图,一半为独立的点,

这样边数还不够,再将左上和右下一一相连,右上和左下一一相连。

很容易发现其补图变形一下就跟它一样,然后找一下对应关系。

#include<bits/stdc++.h>
using namespace std; int n; int main()
{
int T, kase=;
scanf("%d", &T);
while(T--)
{
scanf("%d", &n);
printf("Case #%d: ", ++kase);
if(n % == )
{
printf("Yes\n");
int k = n/;
for(int i = ; i<= k;i++)
{
for(int j = ; j <= *k;j++)
{
if(j == i) printf("");
else printf("");
}
for(int j = *k+;j <= *k;j++) printf("");
for(int j = *k+;j <= *k;j++) printf("");
printf("\n");
}
for(int i = k+;i <= *k;i++)
{
for(int j = ; j <= *k;j++)
{
if(j == i) printf("");
else printf("");
}
for(int j = *k+;j <= *k;j++) printf("");
for(int j = *k+;j <= *k;j++) printf("");
printf("\n");
}
for(int i = *k+;i <= *k;i++)
{
for(int j = ;j <= k;j++) printf("");
for(int j = k+;j <= *k;j++) printf("");
for(int j = *k+;j <= *k;j++) printf("");
printf("\n");
}
for(int i = *k+;i <= *k;i++)
{
for(int j = ;j <= k;j++) printf("");
for(int j = k+;j <= *k;j++) printf("");
for(int j = *k+;j <= *k;j++) printf("");
printf("\n");
}
for(int i = *k;i >= *k+;i--) printf("%d ", i);
for(int i = *k;i >= *k+;i--) printf("%d ", i);
for(int i = k;i >= ;i--) printf("%d ", i);
for(int i = *k;i >= k+;i--) printf("%d%c", i, i == k+? '\n':' ');
}
else if(n % == )
{
printf("Yes\n");
int k = n/;
for(int i = ; i<= k;i++)
{
for(int j = ; j <= *k;j++)
{
if(j == i) printf("");
else printf("");
}
for(int j = *k+;j <= *k;j++) printf("");
for(int j = *k+;j <= *k;j++) printf("");
printf("1\n");
}
for(int i = k+;i <= *k;i++)
{
for(int j = ; j <= *k;j++)
{
if(j == i) printf("");
else printf("");
}
for(int j = *k+;j <= *k;j++) printf("");
for(int j = *k+;j <= *k;j++) printf("");
printf("1\n");
}
for(int i = *k+;i <= *k;i++)
{
for(int j = ;j <= k;j++) printf("");
for(int j = k+;j <= *k;j++) printf("");
for(int j = *k+;j <= *k;j++) printf("");
printf("0\n");
}
for(int i = *k+;i <= *k;i++)
{
for(int j = ;j <= k;j++) printf("");
for(int j = k+;j <= *k;j++) printf("");
for(int j = *k+;j <= *k;j++) printf("");
printf("0\n");
}
for(int i = ;i <= *k;i++) printf("");
for(int i = *k+;i <= *k+;i++) printf("");
printf("\n"); for(int i = *k;i >= *k+;i--) printf("%d ", i);
for(int i = *k;i >= *k+;i--) printf("%d ", i);
for(int i = k;i >= ;i--) printf("%d ", i);
for(int i = *k;i >= k+;i--) printf("%d ", i);
printf("%d\n", *k+);
}
else
{
printf("No\n");
}
}
}

2019牛客多校E Androgynos——自补图&&构造的更多相关文章

  1. 2019牛客多校第一场 I Points Division(动态规划+线段树)

    2019牛客多校第一场 I Points Division(动态规划+线段树) 传送门:https://ac.nowcoder.com/acm/contest/881/I 题意: 给你n个点,每个点有 ...

  2. 2019牛客多校第二场 A Eddy Walker(概率推公式)

    2019牛客多校第二场 A Eddy Walker(概率推公式) 传送门:https://ac.nowcoder.com/acm/contest/882/A 题意: 给你一个长度为n的环,标号从0~n ...

  3. 2019牛客多校第八场 F题 Flowers 计算几何+线段树

    2019牛客多校第八场 F题 Flowers 先枚举出三角形内部的点D. 下面所说的旋转没有指明逆时针还是顺时针则是指逆时针旋转. 固定内部点的答案的获取 anti(A)anti(A)anti(A)或 ...

  4. 2019牛客多校 Round4

    Solved:3 Rank:331 B xor 题意:5e4个集合 每个集合最多32个数 5e4个询问 询问l到r个集合是不是都有一个子集的xor和等于x 题解:在牛客多校第一场学了线性基 然后这个题 ...

  5. 2019牛客多校第一场E ABBA(DP)题解

    链接:https://ac.nowcoder.com/acm/contest/881/E 来源:牛客网 ABBA 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 524288K,其他语 ...

  6. 2019牛客多校第四场 I题 后缀自动机_后缀数组_求两个串de公共子串的种类数

    目录 求若干个串的公共子串个数相关变形题 对一个串建后缀自动机,另一个串在上面跑同时计数 广义后缀自动机 后缀数组 其他:POJ 3415 求两个串长度至少为k的公共子串数量 @(牛客多校第四场 I题 ...

  7. 2019牛客多校第四场 A meeting

    链接:https://ac.nowcoder.com/acm/contest/884/A来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 524288K,其他语言10485 ...

  8. [2019牛客多校第二场][G. Polygons]

    题目链接:https://ac.nowcoder.com/acm/contest/882/G 题目大意:有\(n\)条直线将平面分成若干个区域,要求处理\(m\)次询问:求第\(q\)大的区域面积.保 ...

  9. 2019 牛客多校第一场 D Parity of Tuples

    题目链接:https://ac.nowcoder.com/acm/contest/881/D 看此博客之前请先参阅吕凯飞的论文<集合幂级数的性质与应用及其快速算法>,论文中很多符号会被本文 ...

随机推荐

  1. Azure经典虚拟机(Windows)如何监测单个磁盘的使用空间

    Azure云平台创建经典虚拟机(Windows)后,发现仪表板的监测项下默认是没有针对磁盘空间进行检测的指标的 本地机器安装Windows Azure Powershell模块,并通过如下命令登陆并查 ...

  2. 斜率优化dp学习笔记 洛谷P3915[HNOI2008]玩具装箱toy

    本文为原创??? 作者写这篇文章的时候刚刚初一毕业…… 如有错误请各位大佬指正 从例题入手 洛谷P3915[HNOI2008]玩具装箱toy Step0:读题 Q:暴力? 如果您学习过dp 不难推出d ...

  3. Python 安装包时选择 python版本

    安装了两个版本的python 其中一个版本为2.7 专门为python 2.7安装包使用的语句为 升级pip E:\Python27\python -m pip install --upgrade p ...

  4. gin PostForm 方法不起作用

    情景: 在httpie post 下,在 axios post下,总的来说,就是在form-data下只有c.Bind()会有用 如果一定要用c.PostForm() headers必须为x-www- ...

  5. css 样式合集

    td换行: style="word-wrap:break-word;word-break:break-all;" 超长省略号: table { table-layout: fixe ...

  6. 02 servlet基础 生命周期 tomcat web.xml

    新建web项目 – new Web Project – 选择:javaee 5.0 建包 – com.gzsxt.wang 新建class:FirstServlet – 继承:HttpServlet( ...

  7. ASP.NET Core 入门(4)(IIS 部署前后端站点)

    .NET Core发布部署的文章园内有很多了,大家可以自行百度,该篇主要想总结需要注意的地方,列举前后端(比如前段 Vue,后端 WebAPI)在同一台服务器上的主要两种方式. 两种方式: 1. 前后 ...

  8. 关于GPU的传输速度与什么有关??

    1. i5-8250U   1.6GHz 2. PCIE 3  4K 105fps  =  10.45Gps   4K 一帧  = 99.5Mbit 4K YUV444 + mask = 3840*2 ...

  9. SpringMVC的理论

    围绕Handler开发 数据Model 页面View SpringMVC的运行流程: 1.用户发送一个请求,所有的请求都会映射到DispatcherServlet(中央控制器的servlet,该ser ...

  10. ASE19团队项目 beta阶段 model组 scrum report list

    scrum 1 scrum 2 scrum 3 scrum 4 scrum 5 scrum 6 scrum 7