题目链接

\(Description\)

给出一个n个点的有向图,任意两个点之间有且仅一条有向边。对于每个点v,求出从v出发的一条经过点数最多,且没有重复经过同一个点一次以上的简单路径。

n<=2000

\(Solution\)

详细题解在这

竞赛图缩点后得到的拓扑图一定是一条链,因为竞赛图任意两点前后关系确定,所以只有一种拓扑序列

从前边强连通分量中的任意一点出来 都可以到达后边强连通分量的任意一点

因为竞赛图的每个强连通分量一定存在一条哈密顿回路

所以只需要求出每一个强连通分量的哈密顿回路,然后在链上走,把每个强连通分量的回路存起来中,最后按拓扑序从后往前输出即可

//4884kb	9220ms
#include <cstdio>
#include <cctype>
#include <vector>
#include <algorithm>
#define gc() getchar()
const int N=2005; int n,dfn[N],low[N],id,cnt,bel[N],sk[N],top,nxt[N],dgr[N],pos[N];
bool mp[N][N],ins[N];
std::vector<int> scc[N]; inline int read()
{
int now=0;register char c=gc();
for(;!isdigit(c);c=gc());
for(;isdigit(c);now=now*10+c-'0',c=gc());
return now;
}
void Tarjan(int x)
{
dfn[x]=low[x]=++id, sk[++top]=x, ins[x]=1;
for(int i=1; i<=n; ++i)
if(mp[x][i])
if(!dfn[i]) Tarjan(i),low[x]=std::min(low[x],low[i]);
else if(ins[i]) low[x]=std::min(low[x],dfn[i]);
else ;//
if(low[x]==dfn[x])
{
++cnt;
do{
bel[sk[top]]=cnt, ins[sk[top]]=0, scc[cnt].push_back(sk[top]);
}while(x!=sk[top--]);
}
}
inline bool cmp(const int &a,const int &b){
return dgr[a]<dgr[b];
}
void Insert(int x)
{
sk[++top]=x;
for(int i=nxt[x]; i/*necessary(对于单独一个点)*/&&i!=x; i=nxt[i]) sk[++top]=i;
} int main()
{
n=read();
for(int i=2; i<=n; ++i)
for(int j=1; j<i; ++j)
mp[j][i]=read(), mp[i][j]=mp[j][i]^1;
for(int i=1; i<=n; ++i)
if(!dfn[i]) Tarjan(i);
for(int l,r,sz,i=1; i<=cnt; ++i)
{
l=r=scc[i][0], sz=scc[i].size();
for(int tmp,j=1; j<sz; ++j)//从1个点开始 扩展成哈密顿路径
{
tmp=scc[i][j];
if(mp[tmp][l]) nxt[tmp]=l, l=tmp;
else if(mp[r][tmp]) nxt[r]=tmp, r=tmp;
else
{
for(int k=l; nxt[k]; k=nxt[k])
if(mp[k][tmp]&&mp[tmp][nxt[k]])//在当前路径上找 连向tmp同时tmp连向其后边节点的
{
nxt[tmp]=nxt[k], nxt[k]=tmp;
break;
}
}
}
r=0;
for(int j=l; j; j=nxt[j])
if(r)
{
for(int k=r,las=l; ; las=k,k=nxt[k])
{
if(mp[j][k])
{
nxt[las]=nxt[l];
if(las!=l) nxt[l]=r;
r=k, l=j;
break;
}
if(k==l) break;
}
}
else if(mp[j][l]) r=l, l=j;
nxt[l]=r;
}
for(int i=1; i<=n; ++i)//对每个强连通分量拓扑排序
for(int j=1; j<=n; ++j)
if(bel[i]!=bel[j]&&mp[i][j]) ++dgr[bel[j]];
for(int i=1; i<=cnt; ++i) pos[i]=i, dgr[i]/=scc[i].size();
//度数要除以size 因为连向强连通分量i的点会连向i中所有点(竞赛图) 而此时拓扑是要对强连通分量的入度排序
std::sort(pos+1,pos+1+cnt,cmp);
for(int i=1; i<=n; ++i)
{
top=0, Insert(i);//直接加入i这个强连通分量即可,走一遍回路,然后再从终点走到下一个强连通分量
//bel[i]中每个点一定都可以走到下一个强连通分量j,否则bel[i]和j就成了环(同一个强连通分量)了
for(int j=1; j<=cnt; ++j)//按照拓扑序添加scc(路径)
if(dgr[pos[j]]>dgr[bel[i]])
Insert(scc[pos[j]][0]);
printf("%d ",top);
for(int i=1; i<top; ++i) printf("%d ",sk[i]);
printf("%d\n",sk[top]);
}
return 0;
}

BZOJ.4727.[POI2017]Turysta(哈密顿路径/回路 竞赛图)的更多相关文章

  1. BZOJ 4727: [POI2017]Turysta

    4727: [POI2017]Turysta Time Limit: 20 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 117  Solved ...

  2. BZOJ4727 [POI2017]Turysta 【竞赛图哈密顿路径/回路】

    题目链接 BZOJ4727 题解 前置芝士 1.竞赛图存在哈密顿路径 2.竞赛图存在哈密顿回路,当且仅当它是强联通的 所以我们将图缩点后,拓扑排序后一定是一条链,且之前的块内的点和之后块内的点的边一定 ...

  3. bzoj千题计划232:bzoj4727: [POI2017]Turysta

    http://www.lydsy.com/JudgeOnline/problem.php?id=4727 竞赛图tarjan缩点后得到的拓扑图一定是一条链 因为竞赛图任意两点的前后顺序确定,只有一种拓 ...

  4. BZOJ 4726: [POI2017]Sabota?

    4726: [POI2017]Sabota? Time Limit: 20 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 301  Solved ...

  5. BZOJ 4726: [POI2017]Sabota? 树形dp

    4726: [POI2017]Sabota? 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4726 Description 某个公司有n ...

  6. bzoj 4725 [POI2017]Reprezentacje ró?nicowe 暴力

    [POI2017]Reprezentacje ró?nicowe Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 141  Solved: 67[Sub ...

  7. bzoj 4724 [POI2017]Podzielno 二分+模拟

    [POI2017]Podzielno Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 364  Solved: 160[Submit][Status][ ...

  8. bzoj 4723 [POI2017]Flappy Bird 模拟

    [POI2017]Flappy Bird Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 482  Solved: 196[Submit][Status ...

  9. ACM学习历程—BZOJ 2115 Xor(dfs && 独立回路 && xor高斯消元)

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2115 题目大意是求一条从1到n的路径,使得路径xor和最大. 可以发现想枚举1到n的所有路 ...

随机推荐

  1. 详解Jquery选择器

    1.常见的选择器 id,类,标签选择器. $("#a1") $(".myclass") $("div") 2.组合选择器 $("# ...

  2. Django中全局Context处理器

    1.模板标签和模板变量 模板标签在{% %}中定义: {% if is_logged_in %} Thanks for logging in! {% else %} Please log in. {% ...

  3. Linux之定时器与时间管理 【转】

    转自:http://blog.chinaunix.net/uid-23228758-id-154820.html 定时器与时间管理: 次,为一秒.一般的情况下编程者不要改变这个值,因为内核编很多代码都 ...

  4. oracle删除表字段和oracle表增加字段

    这篇文章主要介绍了oracle表增加字段.删除表字段修改表字段的使用方法,大家参考使用吧   添加字段的语法:alter table tablename add (column datatype [d ...

  5. oracle forall

    select * bulk collect    into r_115    from TZTJ_CL0115   where nf = v_nf     and yf = v_yf     and ...

  6. 自动化运维之cobbler安装centos7.3

    自动化运维之cobbler安装centos7.3 一.cobbler简介和服务 Cobbler是一款自动化操作系统安装的实现,与PXE安装系统的区别就是可以同时部署多个版本的系统,而PXE只能选择一种 ...

  7. 10-关于DOM的事件操作

    一.JavaScript的组成 JavaScript基础分为三个部分: ECMAScript:JavaScript的语法标准.包括变量.表达式.运算符.函数.if语句.for语句等. DOM:文档对象 ...

  8. OCM_第二十天课程:Section9 —》Data Guard _ DATA GUARD 搭建/DATA GUARD 管理

    注:本文为原著(其内容来自 腾科教育培训课堂).阅读本文注意事项如下: 1:所有文章的转载请标注本文出处. 2:本文非本人不得用于商业用途.违者将承当相应法律责任. 3:该系列文章目录列表: 一:&l ...

  9. vue scoped 穿透_vue 修改内部组件样式问题

    何为scoped? 在vue文件中的style标签上,有一个特殊的属性:scoped.当一个style标签拥有scoped属性时,它的CSS样式就只能作用于当前的组件,也就是说,该样式只能适用于当前组 ...

  10. SQL开发测试使用基础

    目录 一.客户端配置与使用    1.oracle(PLSQL Developer)    2.hive(hive cli)及命令    3.postgre(pgAdmin)   二.注意事项及基础 ...