题意:http://www.lydsy.com/JudgeOnline/problem.php?id=1064

   给一个有向图染色,每个点的后继必须相同,问至少&至多有多少种染色方案

sol:  图由多个联通块组成,对于每个联通块,考虑以下3种情况:

   如果有环,分为3类讨论

     

     对于第一种简单环,答案一定是环长的约数

     对于第二种有反向边的环,答案一定是两条链长差的约数

       trick:将有向边化为无向边,正向边权为1,反向为-1

          这样1,2可以一起做

     对于第三种大环套小环,将小环缩点即可(gcd(a,b)=gcd(b,a-b))

     所以答案最大为所有环长的gcd,最小为gcd的约数中>3的最小的一个

   如果是一个森林

     

     则答案最大值为深度之差的最大值,最小值为3

   若最大值<3则无解

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
using namespace std;
const int N=;
const int M=;
int n,m,tot,maxn,minn,ansmin,ansmax;
int dis[N],head[N],vis[N],ver[M],nxt[M],edge[M];
void add(int u,int v,int d)
{
tot++;
nxt[tot]=head[u];
ver[tot]=v;
edge[tot]=d;
head[u]=tot;
}
int gcd(int x,int y)
{
if(!y) return x;
return gcd(y,x%y);
}
void dfs1(int x,int fa)//找环
{
vis[x]=;
for(int i=head[x];i;i=nxt[i])
{
int v=ver[i];
if(v!=fa)
{
if(!vis[v])vis[v]=,dis[v]=dis[x]+edge[i],dfs1(v,x);
else ansmax=gcd(ansmax,abs(dis[x]-dis[v]+edge[i]));
}
}
}
void dfs2(int x,int fa)//处理森林
{
vis[x]=;
maxn=max(dis[x],maxn);
minn=min(minn,dis[x]);
for(int i=head[x];i;i=nxt[i])
{
int v=ver[i];
if(v!=fa)
if(!vis[v])
vis[v]=,dis[v]=dis[x]+edge[i],dfs2(v,x);
}
}
int main()
{
scanf("%d%d",&n,&m);
while(m--)
{
int a,b; scanf("%d%d",&a,&b);
add(a,b,); add(b,a,-);
}
for(int i=;i<=n;i++) if(!vis[i]) dfs1(i,);
if(ansmax) for(ansmin=;ansmin<=ansmax&&ansmax%ansmin;ansmin++);
else
{
ansmin=;memset(vis,,sizeof(vis));
for(int i=;i<=n;i++)
if(!vis[i])
{
maxn=minn=,dis[i]=;
dfs2(i,);ansmax+=maxn-minn+;
}
}
if(ansmax<=) ansmax=ansmin=-;
printf("%d %d\n",ansmax,ansmin);
return ;
}

bzoj 1064【noi2008】假面舞会的更多相关文章

  1. [bzoj 1064][NOI2008]假面舞会(dfs判断环)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1064 分析: 如果a看到b,则a->b 那么: 1.如果图中有环,则说明这个环的 ...

  2. [BZOJ]1064: [Noi2008]假面舞会

    题目大意:n个人,k种假面,每人戴一种,戴第i种的可以看见第i+1种,戴第k种的可以看见第1种,给出m条关系表示一个人可以看到另一个人,问k可能的最大值和最小值.(n<=100,000,m< ...

  3. BZOJ 1064: [Noi2008]假面舞会(dfs + 图论好题!)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1064 题意: 思路: 考虑以下几种情况: ①无环并且是树: 无环的话就是树结构了,树结构的话想一下就 ...

  4. bzoj 1064 noi2008 假面舞会题解

    莫名其妙的变成了我们的noip互测题... 其实这题思想还是比较简单的,只是分类不好分而已 其实就是一个dfs的事 首先,非常明显,原题目中的所有关系可以抽象成一个图(这是...显而易见的吧...) ...

  5. 【BZOJ】1064: [Noi2008]假面舞会(判环+gcd+特殊的技巧)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1064 表示想到某一种情况就不敢写下去了.... 就是找环的gcd...好可怕.. 于是膜拜了题解.. ...

  6. 1064: [Noi2008]假面舞会 - BZOJ

    Description 一年一度的假面舞会又开始了,栋栋也兴致勃勃的参加了今年的舞会.今年的面具都是主办方特别定制的.每个参加舞会的人都可以在入场时选择一 个自己喜欢的面具.每个面具都有一个编号,主办 ...

  7. 图论 公约数 找环和链 BZOJ [NOI2008 假面舞会]

    BZOJ 1064: [Noi2008]假面舞会 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1655  Solved: 798[Submit][S ...

  8. NOI2008假面舞会

    1064: [Noi2008]假面舞会 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 883  Solved: 462[Submit][Status] ...

  9. [BZOJ1064][Noi2008]假面舞会

    [BZOJ1064][Noi2008]假面舞会 试题描述 一年一度的假面舞会又开始了,栋栋也兴致勃勃的参加了今年的舞会.今年的面具都是主办方特别定制的.每个参加舞会的人都可以在入场时选择一 个自己喜欢 ...

  10. 【洛谷】1477:[NOI2008]假面舞会【图论】

    P1477 [NOI2008]假面舞会 题目描述 一年一度的假面舞会又开始了,栋栋也兴致勃勃的参加了今年的舞会. 今年的面具都是主办方特别定制的.每个参加舞会的人都可以在入场时选择一 个自己喜欢的面具 ...

随机推荐

  1. 前阿里CEO卫哲谈阿里创业经验:如何找人、找钱、找方向?(不同的阶段分别有:时间优先、金额优先、比例优先,不要做平台,太难)

    新浪科技李根 整理报道 卫哲现在是御嘉基金的创始合伙人,他另一个更加知名的身份是阿里巴巴(B2B)前CEO,在2006年到2011年的时间里,卫哲见证了阿里巴巴如何利用人才.资本和方向选择一路壮大. ...

  2. 深入php面向对象和模式

    前两章是php历史和概论,略过. 第三章 对象基础 3.1 类和对象 类,是用于生成对象的代码模版. public 公有的,都可调用. protected 保护的, 只有本类和子类可以调用. priv ...

  3. ArcGIS Engine 连接SQL Server并建立关联

    IWorkspaceFactory  pWFactory=new OLEDBWorkspaceFactory(); IPropertySet  pPropertySet=new  PropertySe ...

  4. 几种java通信(rmi,http,hessian,webservice)协议性能比较

    一.综述 本文比较了RMI,Hessian,Burlap,Httpinvoker,web service等5种通讯协议的在不同的数据结构和不同数据量时的传输性能.RMI是java语言本身提供的通讯协议 ...

  5. windows编译 obs-studio

    github下载源码 https://github.com/jp9000/obs-studio 还需要一个开发包 http://code.fosshub.com/OBS/download/depend ...

  6. freemarker跳出循环

    break语句跳出当前循环,如下: <#list table.columns as c>             <#if c.isPK>                 &l ...

  7. POJ 1273 (基础最大流) Drainage Ditches

    虽然算法还没有理解透,但以及迫不及待地想要A道题了. 非常裸的最大流,试试lrj的模板练练手. #include <cstdio> #include <cstring> #in ...

  8. SDOI2008Cave 洞穴勘测

    无限膜拜CLJ大牛…… 不会动态树的弱弱在CLJ的帮助下AC了此题 我想到了并查集(人人都会想到的吧……囧),但不知道应该如何处理destroy操作…… 其实 make操作的实质就是:把x节点到其所在 ...

  9. php简单实现MVC

    在PHP中使用MVC越来越流行了,特别是在一些开源的框架当中.MVC足以应对大多数的情况,但还有一些情况是其不太适合的,如比较简单的个人博客,对于只有几百篇文章量级的博客,使用MVC让人觉得有些太复杂 ...

  10. mysql 触发器学习(可以将mysql数据同步到redis)

    1. 一个简单的例子 1.1. 创建表: create table t(s1 integer); 1.2. 触发器: delimiter | create trigger t_trigger befo ...