博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bzoj 1823: [JSOI2010]满汉全席
阅读量:6422 次
发布时间:2019-06-23

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

1 #include
2 #include
3 #include
4 using namespace std; 5 int t,n,m,head[205],next[2005],v[2005],cnt,dfn[205],cnt1,low[205]; 6 int zhan[205],zhan1[205],top,shu[205],shu1; 7 int du() 8 { 9 int a1; 10 char ch; 11 ch=getchar(); 12 for(;ch!='m'&&ch!='h';ch=getchar()); 13 scanf("%d",&a1); 14 if(ch=='m') 15 return a1*2; 16 else 17 return a1*2-1; 18 } 19 void jia(int a1,int a2) 20 { 21 cnt++; 22 next[cnt]=head[a1]; 23 head[a1]=cnt; 24 v[cnt]=a2; 25 return; 26 } 27 void dfs(int a1) 28 { 29 cnt1++; 30 low[a1]=dfn[a1]=cnt1; 31 zhan[a1]=1; 32 top++; 33 zhan1[top]=a1; 34 for(int i=head[a1];i;i=next[i]) 35 if(!dfn[v[i]]) 36 { 37 dfs(v[i]); 38 low[a1]=min(low[a1],low[v[i]]); 39 } 40 else 41 if(zhan[v[i]]) 42 low[a1]=min(low[a1],dfn[v[i]]); 43 if(low[a1]==dfn[a1]) 44 { 45 shu1++; 46 for(int i=zhan1[top];i!=a1;top--,i=zhan1[top]) 47 { 48 shu[i]=shu1; 49 zhan[i]=0; 50 } 51 top--; 52 shu[a1]=shu1; 53 zhan[a1]=0; 54 } 55 return; 56 } 57 int main() 58 { 59 scanf("%d",&t); 60 for(int i=0;i

2-set问题,根据评委需求建边,比如h1,h2那m2向h1建边,m1向h2建边。求2-set时用tarjin找环。

转载于:https://www.cnblogs.com/xydddd/p/5281983.html

你可能感兴趣的文章
移动端适配知识你到底知多少
查看>>
TiDB 在 G7 的实践和未来
查看>>
重新认识javascript对象(三)——原型及原型链
查看>>
小学生学“数学”
查看>>
FastDFS蛋疼的集群和负载均衡(十七)之解决LVS+Keepalived遇到的问题
查看>>
深入剖析Redis系列(二) - Redis哨兵模式与高可用集群
查看>>
Android 用于校验集合参数的小封装
查看>>
iOS混合开发库(GICXMLLayout)七、JavaScript篇
查看>>
instrument 调试 无法指出问题代码 解决
查看>>
理解缓存
查看>>
BAT 经典算法笔试题 —— 磁盘多路归并排序
查看>>
Nginx限制带宽
查看>>
All Web Application Attack Techniques
查看>>
归档日志ORA-19809: 超出了恢复文件数的限制
查看>>
精品德国软件 UltraShredder 文件粉碎机
查看>>
PANDAS 数据合并与重塑(join/merge篇)
查看>>
文件时间信息在测试中的应用
查看>>
直播疑难杂症排查(8)— 播放杂音、噪音、回声问题
查看>>
如何写gdb命令脚本
查看>>
Android ListView展示不同的布局
查看>>