Codeforces 510 E. Fox And Dinner
题目链接:http://codeforces.com/problemset/problem/510/E
乍一看和那啥魔术球问题有点神似啊/XD
其实是不一样的。
解决这道问题的关键在于发现若是相邻的两个数的和是质数,那么他们必定是一奇一偶!
而且一个奇数旁边一定是两个偶数,一个偶数旁边一定是两个奇数(因为是一个大于$3$的环)
秒啊!这就变成了匹配模型。
源点向所有值为奇数的点连容量为$2$边,值为奇数的点向所有与它的和为质数的且值为偶数点连容量为$1$边,所有值为偶数的点向汇点连容量为$2$的边。
跑一边最大流,我们是不是就求出了最大的合法的匹配方案?
如果最大流为$n$才说明了每一个点都匹配上了。
考虑输出方案,$DFS$在$Dinic$之后留下的图,如果流量发生了变化则沿这条路径走下去(当然不能走到源点或者汇点)
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<vector>
#include<cstdlib>
#include<cmath>
#include<cstring>
using namespace std;
#define maxn 1010
#define inf 0x7fffffff
#define llg int
#define yyj(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
llg n,m,ans,c[maxn],cnt1,cnt2,tot[maxn];
llg d[maxn][maxn];
inline int getint()
{
int w=,q=; char c=getchar();
while((c<'' || c>'') && c!='-') c=getchar(); if(c=='-') q=,c=getchar();
while (c>='' && c<='') w=w*+c-'', c=getchar(); return q ? -w : w;
} struct DINIC
{
llg N;
vector<llg>a[maxn],ba[maxn],val[maxn],stval[maxn];
llg dl[maxn],deep[maxn];
bool bj[maxn]; void link(llg x,llg y,llg z)
{
a[x].push_back(y),val[x].push_back(z); stval[x].push_back(z);
a[y].push_back(x),val[y].push_back(); stval[y].push_back();
ba[x].push_back(a[y].size()-),ba[y].push_back(a[x].size()-);
} llg dfs(llg x,llg low)
{
llg va=,inc=;
if (x==N) return low;
llg w=a[x].size(),v;
for (llg i=;i<w;i++)
{
v=a[x][i];
if (deep[x]+==deep[v] && val[x][i]> && (va=dfs(v,min(low,val[x][i]))))
{
val[x][i]-=va; val[v][ba[x][i]]+=va; inc+=va;
return va;
}
}
if (!inc) deep[x]=-;
return ;
} void fencen()
{
llg x,w,v; deep[]=;
memset(bj,,sizeof(bj));
llg head=,tail=; dl[]=; bj[]=;
do
{
x=dl[++head]; w=a[x].size();
for (llg i=;i<w;i++)
{
v=a[x][i];
if (bj[v] || val[x][i]<=) continue;
dl[++tail]=v;
deep[v]=deep[x]+; bj[v]=;
}
}while (head!=tail);
} llg dinic()
{
llg ans=;
while ()
{
fencen();
if (!bj[N]) break;
ans+=dfs(,inf);
}
return ans;
} void DFS(llg x)
{
bj[x]=;
tot[ans]++;
d[ans][tot[ans]]=x;
llg w=a[x].size(),v;
for (llg i=;i<w;i++)
{
v=a[x][i];
if (v== || v==N || bj[v]) continue;
if (stval[x][i]==val[x][i]) continue;
DFS(v);
}
} bool pd(llg x)
{
llg cs=,w=a[x].size(),v;
for (llg i=;i<w;i++)
{
v=a[x][i];
if (v== || v==N) continue;
if (bj[v] || val[x][i]==stval[x][i]) continue;
cs++;
}
if (cs>) return ;else return ;
} void make_ans()
{
memset(bj,,sizeof(bj));
while ()
{
bool WK=;
for (llg i=;i<=n;i++)
if (!bj[i])
{
if (!pd(i)) continue;
WK=;
ans++;
DFS(i);
}
if (!WK) break;
}
}
}G; bool check(llg v1,llg v2)
{
llg x=v1+v2;
llg up=sqrt(x+);
for (llg i=;i<=up;i++)
if (x%i==) return ;
return ;
} void init()
{
cin>>n;
for (llg i=;i<=n;i++) c[i]=getint();
for (llg i=;i<=n;i++)
{
if (c[i]%) G.link(,i,),cnt1++; else G.link(i,n+,),cnt2++;
if (c[i]%==) continue;
for (llg j=;j<=n;j++)
if (i!=j && check(c[i],c[j]))
G.link(i,j,);
}
G.N=n+;
} int main()
{
yyj("flows");
init();
if (cnt1!=cnt2) {cout<<"Impossible"; return ;}
llg flows=G.dinic();
if (flows!=n) {cout<<"Impossible"; return ;}
G.make_ans();
cout<<ans<<endl;
for (llg i=;i<=ans;i++)
{
cout<<tot[i]<<" ";
for (llg j=;j<=tot[i];j++) cout<<d[i][j]<<" ";
cout<<endl;
}
return ;
}
Codeforces 510 E. Fox And Dinner的更多相关文章
- Codeforces 510 A.Fox and Snake
题目链接:http://codeforces.com/contest/510/problem/A A. Fox And Snake time limit per test2 seconds memor ...
- 网络流(最大流)CodeForces 512C:Fox And Dinner
Fox Ciel is participating in a party in Prime Kingdom. There are n foxes there (include Fox Ciel). T ...
- codeforces 510 C Fox And Names【拓扑排序】
题意:给出n串名字,表示字典序从小到大,求符合这样的字符串排列的字典序 先挨个地遍历字符串,遇到不相同的时候,加边,记录相应的入度 然后就是bfs的过程,如果某一点没有被访问过,且入度为0,则把它加入 ...
- CodeForces Round #290 Fox And Dinner
而是Div2的最后一题,当时打比赛的时候还不会最大流.自己能够把它写出来然后1A还是很开心的. 题意: 有n个不小于2的整数,现在要把他们分成若干个圈.在每个圈中,数字的个数不少于3个,而且相邻的两个 ...
- 【Codeforces】512C Fox and Dinner
[解析]欧拉筛法,奇偶分析.建二分图,网络流 [Analysis] http://blog.csdn.net/qq574857122/article/details/43453087. 所谓的连通块就 ...
- Codeforces Round #290 (Div. 2) E. Fox And Dinner 网络流建模
E. Fox And Dinner time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...
- CF510E. Fox And Dinner
CF510E. Fox And Dinner https://codeforces.com/contest/510 分析: 由于\(a_i>2\), 相邻两个数一定一奇一偶,按奇偶建立二分图. ...
- (CodeForces 510C) Fox And Names 拓扑排序
题目链接:http://codeforces.com/problemset/problem/510/C Fox Ciel is going to publish a paper on FOCS (Fo ...
- 网络流 I - Fox And Dinner CodeForces - 510E
Fox Ciel is participating in a party in Prime Kingdom. There are n foxes there (include Fox Ciel). T ...
随机推荐
- MyEclipse如何修改XML文件默认行宽
1.MyEclipse如何修改XML文件默认行宽 Windows--->Preferences--->搜索xml--->XML--->XML Source--->Form ...
- EDK II之USB协议栈的实现简介
本文旨在简单介绍一下 UEFI中USB协议栈的代码框架: 主要包括: USB主控制器驱动(HCDI:EFI_USB2_HC_PROTOCOL) USB总线驱动(USBDI:EFI_USB_IO_PRO ...
- 作为php了解一下共享内存的概念及优缺点
共享内存是一种在相同机器中两个正在运行的进程之间共享和传递数据的有效方式,不同进程之间共享的内存通常安排为同一段物理内存:顾名思义,共享内存就是允许两个不相关的进程访问同一个逻辑内存.一个进程可创建一 ...
- django模板-通过a标签生成链接并跳转
views.py from django.shortcuts import render from django.http import HttpResponse def index(request) ...
- U盘中病毒,文件消失或不显示
最近非常流行的一个病毒,将电脑或者U盘里的文件全部用快捷方式替换,真实文件被隐藏起来,下面我们就具体了解下此种病毒吧,做好预防与杀毒工作. 一.病毒名称 病毒名称:移动盘同名文件夹病毒;文件夹EXE病 ...
- 深度学习demo
1. Stanford Convolutional Neural Network on the MNIST digits dataset http://cs.stanford.edu/people/k ...
- 2018-2019-1 20189206 《Linux内核原理与分析》第五周作业
linux内核分析学习笔记 --第四章 系统调用的三层机制 学习重点--系统调用 用户态.内核态和中断 Intel x86 CPU有四种不同的执行级别,分别是0,1,2,3其中数字越小,特权越高. L ...
- nginx 下 php 无法执行,虚拟主机 无法使用
检查目录下的.ini文件 有可能是因为多了个user.ini文件.这个文件在linux下可用,在window下不可用. windows下删掉这个文件后记得重启一下nginx.不然不会生效. 参考:ht ...
- ListView与ArrayAdapter(二)
ArrayAdapter: 数组适配器,用于简单的文字列表 activity_main.xml <RelativeLayout xmlns:android="http://schema ...
- Ubuntu + CUDA9 + CUDNN7 + OpenCV3.4 + contrib +CAFFE-master
安装ubuntu时赞美Rufus(建议ubuntu16.04.04),过程参考 https://www.cnblogs.com/willnote/p/6725594.html 安 装 前 一 定 要 ...