题目

给出一个 $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. [转帖]超详细的PostgreSQL体系结构总结,值得收藏

    超详细的PostgreSQL体系结构总结,值得收藏 https://www.toutiao.com/i6715390855772897800/ 原创 波波说运维 2019-07-26 00:03:00 ...

  2. [转帖]CentOS 8 正式发布

    CentOS 8 正式发布   终于发布了.. https://news.cnblogs.com/n/640416/ 前几天刚弄完centos7.7 的环境. CentOS 8 官方正式发布了!!!C ...

  3. K8S从入门到放弃系列-(3)部署etcd集群

    摘要:etcd 是k8s集群最重要的组件,用来存储k8s的所有服务信息, etcd 挂了,集群就挂了,我们这里把etcd部署在master三台节点上做高可用,etcd集群采用raft算法选举Leade ...

  4. 使用 IDEA 创建 maven 项目

    文章目录 第一步 第二步 第三步 目录结构的设置 看下 web.xml 配置文件 第一步 点击 maven : 勾选从模板创建 : 选择 webapp : 第二步 第三步 如果你自己对 maven 进 ...

  5. IBM Security AppScan Standard使用方法

    一.常规配置Appscan (安全自动化测试工具) Appscan是web应用程序渗透测试舞台上使用最广泛的工具之一.它是一个桌面应用程序,它有助于专业安全人员进行Web应用程序自动化脆弱性评估.本文 ...

  6. 1269: 划分数(Java)

    WUSTOJ 1269: 划分数 参考博客 果7的博客 题目   将 1 个数 n 分成 m 份,求划分的种数.更多内容点击标题. 分析   唯一需要注意的地方是不考虑顺序.其他的直接看代码即可. 代 ...

  7. vue中设置全局的css样式

    只需在main.js    ====import './style.less'   main.js =>>   import Vue from 'vue' import App from ...

  8. SAS学习笔记33 格式修饰符

    冒号(:)格式修饰符 从非空格开始读取变量所对应的数据,直到满足以下任何一种情况 遇到下一个空格列 对应变量所定义的长度已经读满 数据行结束 &格式修饰符 修饰所读取为字符型的列数据中含有一个 ...

  9. linux运维工程师常用命令

    1.ls [选项] [目录名 | 列出相关目录下的所有目录和文件 -a  列出包括.a开头的隐藏文件的所有文件-A  通-a,但不列出"."和".."-l  列 ...

  10. css之word-wrap和word-break的区别

    对于英文单词,如果有一个连写且长度很长的英文单词,在第一行显示不下的情况下,浏览器默认不会截断显示,而是把这个单词整体挪到下一行.但是当整体挪到下一行还是显示不完全该肿么办呢?有如下两个方法: wor ...