博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CF1178D Prime Graph
阅读量:4700 次
发布时间:2019-06-09

本文共 902 字,大约阅读时间需要 3 分钟。

读懂题之后发现条件一和条件二并没有什么用

然后对于条件四显然可以将整个图连成一个环
然后考虑条件三怎么满足?
假如点数正好是质数,直接就满足了
否则
此时所有点的度数都是2。
给每个点多连一条边,度数依然是质数
发现这样最多可以连\(\lfloor \frac{n}{2} \rfloor\)条边,1000以内的合数与最近的质数没有超过\(\lfloor \frac{n}{2} \rfloor\)的,所以枚举一下质数,直接连就行了
代码:

#include
#include
#include
using namespace std;#define rg registervoid read(int &x){ char ch;bool ok; for(ok=0,ch=getchar();!isdigit(ch);ch=getchar())if(ch=='-')ok=1; for(x=0;isdigit(ch);x=x*10+ch-'0',ch=getchar());if(ok)x=-x;}const int maxn=1110,N=1100;int n,pri[maxn],tot,m;bool vis[maxn];void prepare(){ vis[1]=1; for(rg int i=2;i<=N;i++){ if(!vis[i])pri[++tot]=i; for(rg int j=1;j<=tot&&pri[j]*i<=N;j++){ vis[pri[j]*i]=1; if(i%pri[j]==0)break; } }}int main(){ read(n),prepare(); if(!vis[n]){ printf("%d\n",n); for(rg int i=1;i

转载于:https://www.cnblogs.com/lcxer/p/11242355.html

你可能感兴趣的文章
[CCF2015.09]题解
查看>>
[NYIST15]括号匹配(二)(区间dp)
查看>>
json_value.cpp : fatal error C1083: 无法打开编译器生成的文件:No such file or directory
查看>>
洛谷 P1101 单词方阵
查看>>
Swift DispatchQueue
查看>>
C#和JAVA 访问修饰符
查看>>
小甲鱼OD学习第1讲
查看>>
HDU-1085 Holding Bin-Laden Captive-母函数
查看>>
php提示undefined index的几种解决方法
查看>>
LRJ
查看>>
Struts2环境搭建
查看>>
Linux: Check version info
查看>>
stl学习之测试stlen,cout等的运行速度
查看>>
魔戒三曲,黑暗散去;人皇加冕,光明归来
查看>>
Error和Exception
查看>>
Python和Singleton (单件)模式[转载]
查看>>
httpclient设置proxy与proxyselector
查看>>
IT常用单词
查看>>
拓扑排序
查看>>
NYOJ--32--SEARCH--组合数
查看>>