bzoj 1064 图论
我们根据能否看见建图,有向图边权设成1,然后我们转成无向图,
对于每条有向边连一条反边,边权是-1,然后从每个块中任意一个点开始
dfs,每个点有一个值,经过一条边到另一个点之后,用原来的点值和边权
更新新的点的点值,那么如果我们访问到了一个原来已经走过的点,那么我们
找到了一个环(可能是非环,就是一个点出两条有向边,然后又交在一点了),由于
数据是合法的,所以这样的非环的现在应该更新成的点值和原有的点值相等,如果不相等
的话,取差值的绝对值,就是这个环的长度。
那么我们对于所有块,每个块的环的长度都是种类数的倍数,所以取gcd就好了
还有一种情况就是没有环,全都是以链的形式存在的,对于这种形式,我们每个块
染色,然后找到每个块中点值最大的最小的差值就是最长链的长度。
无解的情况比较容易讨论,在此不再赘述。
/**************************************************************
Problem:
User: BLADEVIL
Language: Pascal
Result: Accepted
Time: ms
Memory: kb
****************************************************************/
{$M 65536000}
//By BLADEVIL
var
n, m :longint;
pre, other, len :array[..] of longint;
last :array[..] of longint;
l :longint;
flag :array[..] of boolean;
size, father, key, tmin, tmax :array[..] of longint;
g :array[..] of longint;
ans1, ans2 :longint;
procedure swap(var a,b:longint);
var
c :longint;
begin
c:=a; a:=b; b:=c;
end;
function min(a,b:longint):longint;
begin
if a>b then min:=b else min:=a;
end;
function max(a,b:longint):longint;
begin
if a>b then max:=a else max:=b;
end;
function gcd(a,b:longint):longint;
begin
if b>a then swap(a,b);
if b= then exit(a) else exit(gcd(b,a mod b));
end;
procedure connect(x,y,z:longint);
begin
inc(l);
pre[l]:=last[x];
last[x]:=l;
other[l]:=y;
len[l]:=z;
end;
procedure dfs(x:longint);
var
q, p :longint;
begin
flag[x]:=true;
q:=last[x];
while q<> do
begin
p:=other[q];
if len[q]= then father[p]:=x;
if not flag[p] then
begin
flag[p]:=true;
size[p]:=size[x]+len[q];
key[p]:=key[x];
dfs(p);
end else
begin
inc(g[]);
g[g[]]:=abs(size[x]+len[q]-size[p]);
if g[g[]]= then dec(g[]);
end;
q:=pre[q];
end;
end;
procedure init;
var
i :longint;
x, y :longint;
begin
read(n,m);
for i:= to m do
begin
read(x,y);
connect(x,y,);
connect(y,x,-);
end;
for i:= to n do father[i]:=-;
for i:= to n do if not flag[i] then dfs(i);
end;
procedure main;
var
i :longint;
begin
if g[]= then
begin
fillchar(flag,sizeof(flag),false);
for i:= to n do if (father[i]=-) and (key[i]=) then
begin
key[i]:=i;
dfs(i);
end;
for i:= to n do tmax[i]:=-maxlongint;
for i:= to n do tmin[i]:=maxlongint;
for i:= to n do
begin
tmax[key[i]]:=max(tmax[key[i]],size[i]);
tmin[key[i]]:=min(tmin[key[i]],size[i]);
end;
for i:= to n do if tmin[i]<>maxlongint then inc(ans1,tmax[i]-tmin[i]+);
if ans1< then
begin
writeln(-,' ',-);
exit;
end else
begin
writeln(ans1,' ',);
exit;
end;
end else
begin
ans1:=g[];
for i:= to g[] do
ans1:=gcd(ans1,g[i]);
if ans1< then
begin
writeln(-,' ',-);
exit;
end else
begin
ans2:=;
for i:= to ans1 do
if ans1 mod i= then
begin
ans2:=i;
break;
end;
if ans2= then ans2:=ans1;
writeln(ans1,' ',ans2);
end;
end;
end;
begin
init;
main;
end.
bzoj 1064 图论的更多相关文章
- BZOJ 1064: [Noi2008]假面舞会(dfs + 图论好题!)
http://www.lydsy.com/JudgeOnline/problem.php?id=1064 题意: 思路: 考虑以下几种情况: ①无环并且是树: 无环的话就是树结构了,树结构的话想一下就 ...
- bzoj 1064 假面舞会 图论??+dfs
有两种情况需要考虑 1.链:可以发现对最终的k没有影响 2.环:如果是真环(即1->2->3->4->1),可以看出所有可行解一定是该环的因数 假环呢??(1->2-&g ...
- BZOJ 1064 假面舞会(NOI2008) DFS判环
此题,回想Sunshinezff学长给我们出的模拟题,原题啊有木有!!此处吐槽Sunshinezff爷出题不人道!! 不过也感谢Sunshinezff学长的帮助,我才能做出来.. 1064: [Noi ...
- bzoj 1064
题意:戳这里 思路:很明显是一个图论模型.. 就两种图形: 1.图中存在环,那么就是所有环的gcd为最大答案.gcd的大于3的最小约数为最小答案 2.不存在环,那么是每个弱连通块的最长链之和为最大答案 ...
- [bzoj 1064][NOI2008]假面舞会(dfs判断环)
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1064 分析: 如果a看到b,则a->b 那么: 1.如果图中有环,则说明这个环的 ...
- bzoj 1064【noi2008】假面舞会
题意:http://www.lydsy.com/JudgeOnline/problem.php?id=1064 给一个有向图染色,每个点的后继必须相同,问至少&至多有多少种染色方案 sol: ...
- BZOJ 1064 假面舞会
http://www.lydsy.com/JudgeOnline/problem.php?id=1064 思路:第一眼看的时候以为是差分约束,但是是做不了的,不过能保证的就是这题绝对是图论题...(废 ...
- [BZOJ]1064: [Noi2008]假面舞会
题目大意:n个人,k种假面,每人戴一种,戴第i种的可以看见第i+1种,戴第k种的可以看见第1种,给出m条关系表示一个人可以看到另一个人,问k可能的最大值和最小值.(n<=100,000,m< ...
- bzoj 1064 noi2008 假面舞会题解
莫名其妙的变成了我们的noip互测题... 其实这题思想还是比较简单的,只是分类不好分而已 其实就是一个dfs的事 首先,非常明显,原题目中的所有关系可以抽象成一个图(这是...显而易见的吧...) ...
随机推荐
- javascript的优美与鸡肋
--总结来自:<javascript语言精粹> 任何语言都有其优美的地方和其鸡肋的地方.避归一些语言的糟粕,能相应的降低bug出现的几率. 优美处: 函数是头等对象 基于原型继承的动态对象 ...
- vux用法
其实官网写的很详细了 但是好多时候没有仔细看的耐心 下面基本也是vux官网步骤: 很多人需要$t未定义问题 其实按着官网来就能解决这个报错: 如果你遇到 $t 报错问题,请不要开 issue,升级 v ...
- PHP将两个数组相加
$arr_a=[1=>1,2=>2,3=>3];$arr_b=[1=>'a',4=>4];print_r($arr_a+$arr_b);返回结果:Array ( [1] ...
- 第三十四篇 Python面向对象之 反射(自省)
什么是反射? 反射的概念是由Smith在1982年提出的,主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省).这一概念的提出很快引发了计算机科学领域关于应用反射性的研究.它首先被程序语 ...
- 【SpringCloud】第二篇: 服务消费者(rest+ribbon)
前言: 必需学会SpringBoot基础知识 简介: spring cloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理.服务发现.断路器.路由.微代理.事件总线.全局锁.决策竞选. ...
- 目标检测之Faster-RCNN的pytorch代码详解(数据预处理篇)
首先贴上代码原作者的github:https://github.com/chenyuntc/simple-faster-rcnn-pytorch(非代码作者,博文只解释代码) 今天看完了simple- ...
- DFS(1)——hdu1518Square
一.题目回顾 题目链接:Square 题意:给你M根木棒,请判断这些木棒能否组成正方形. 二.解题思路 DFS+剪枝 [变量说明] sum:木棒的总长度 ave:形成的正方形的边长 maxlen:最长 ...
- 第十三次ScrumMeeting会议
第十三次Scrum Meeting 时间:2017/12/1 地点:咖啡馆 人员:策划组美工组 名字 完成的工作 计划工作 蔡帜 完成公式的基本策划,Bug数量产生机制设计 科技树方面机制确定 游心 ...
- unity 归纳
1.获取控件四个角在屏幕上的坐标 Vector3[] corners = new Vector3[]; gameObject.GetComponent<RectTransform>().G ...
- hadoop自定义数据类型
统计某手机数据库的每个手机号的上行数据包数量和下行数据包数量 数据库类型如下: 数据库内容如下: 下面自定义类型SimLines,类似于平时编写的model import java.io.DataIn ...