不止代码:路径数量(ybtoj-最小生成树)

文章目录

  • 题目描述
  • 解析
  • 代码

题目描述

在这里插入图片描述

解析

乍一看:是个水题啊!
显然如果途径存在强连通的点,路径就会变为正无穷
所以缩点加拓扑dp以及一些特判应该就可以解决了!
一交:40分。。。
然后就开始拆东墙补西墙的debug。。。
de到80之后实在无计可施,看了测试数据
最终在交了10余次后切掉了本题(泪目)
总结一下遇见的问题吧:

1.是所以超过36500的点视为相等,而不是有超过36500的点就全部认为相等!(gg:省选的亏还是没吃够啊。。。)
2.判断强连通特判的位置应该在topu的while大循环的里面而不是判断出边的地方(如果这里不像人话可以看下面的代码有注释说明),否则入度为0的强连通会统计不上
3.有自环!!!!路径也相当于正无穷!(就是这个地方卡80分一直没想到,以后要培养题里没说没有就要考虑自环、重复路径的思维)
4.在2的判断的位置,不是所有有自环的或强连通都是可以的,至少。。它得能走到n+1点啊。。。

总的来说,本题是一道考验严谨思维的题,数据出的很好,提升了本题的质量
我也要提升自己的质量!

代码

#include<bits/stdc++.h>
#define ll long long
#define mem(a,b) memset(a,b,sizeof(a))
using namespace std;
const int N=2e6+100;
const int M=2e6+100;
const int X=36500;
int n,m;
int cnt=-1,fi[N];
struct node{int to,nxt;
}p[M];
void addline(int x,int y){p[++cnt]=(node){y,fi[x]};fi[x]=cnt;
}
int a,b;
int zhan[N],dfs[N],low[N],col[N];
int ed,tot,tim;
int size[N];
int self[N];
void tarjan(int x){zhan[++ed]=x;dfs[x]=low[x]=++tim;for(int i=fi[x];~i;i=p[i].nxt){int u=p[i].to;if(dfs[u]==0){tarjan(u);low[x]=min(low[x],low[u]);}else if(col[u]==0) low[x]=min(low[x],low[u]);}if(low[x]==dfs[x]){col[x]=++tot;size[tot]=1;if(self[x]) self[tot]=1;while(zhan[ed]!=x){if(self[zhan[ed]]) self[tot]=1;col[zhan[ed--]]=tot;size[tot]++;}ed--;}
}
int flag,dp[N],ru[N];
void topu(){queue<int>q;for(int i=n+1;i<=tot;i++) if(ru[i]==0) q.push(i);while(!q.empty()){int now=q.front();q.pop();
//		printf("now=%d\n",now);if(self[now]&&dp[now]||dp[now]>X||(dp[now]&&size[now]!=1)){dp[now]=36501;}//刚才第二条说的就是上面的这个特判不能写在下面的A处for(int i=fi[now];~i;i=p[i].nxt){int u=p[i].to;//A处就是这里啦
//			printf("now=%d to=%d\n",now,u);dp[u]+=dp[now];if(--ru[u]==0){q.push(u);}}}
}
int ans,num,jd[N];
int main(){scanf("%d%d",&n,&m);n++;tot=n;mem(fi,-1);for(int i=1;i<=m;i++){scanf("%d%d",&a,&b);if(a==b) self[a]=1;else addline(b,a);//反向建图 }for(int i=1;i<=n;i++){if(!dfs[i]) tarjan(i);}for(int i=1;i<=n;i++){int xx=col[i];for(int j=fi[i];~j;j=p[j].nxt){int yy=col[p[j].to];if(xx!=yy){addline(xx,yy);ru[yy]++;}}}
//	for(int i=1;i<=n+1;i++) printf("i=%d col=%d size=%d\n",i,col[i],size[col[i]]);dp[col[n]]=1;topu();
//	for(int i=1;i<=n;i++) printf("i=%d dp=%d\n",i,dp[col[i]]); for(int i=n+1;i<=tot;i++){if(dp[i]>36500){flag=1,ans=36501;break;}else ans=max(ans,dp[i]);}for(int i=n+1;i<=tot;i++){if(dp[i]>=ans){num+=size[i];jd[i]=1;}}if(ans<=36500) printf("%d\n",ans);else printf("zawsze\n");printf("%d\n",num);for(int i=1;i<=n;i++){if(jd[col[i]]) printf("%d ",i);}return 0;
}
/*
3 2
3 4
4 3
*/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/318657.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

重磅!!!微软发布.NET Core 2.2

我们很高兴地宣布发布.NET Core 2.2。它包括对运行时的诊断改进&#xff0c;对ARM32 for Windows和Azure Active Directory for SQL Client的支持。此版本中最大的改进是在ASP.NET Core中。ASP.NET Core 2.2和Entity Framework Core 2.2。您可以在Windows&#xff0c;macOS和Li…

[翻译] ASP.NET Core 2.2 正式版发布

本文为翻译&#xff0c;原文地址&#xff1a;https://blogs.msdn.microsoft.com/webdev/2018/12/04/asp-net-core-2-2-available-today/我&#xff08;文章作者&#xff09;很高兴地宣布ASP.NET Core 2.2现在作为.NET Core 2.2的一部分提供&#xff01;怎么获取它您可以从 .NET…

理解至上:数位dp(ybtoj-B数计数)

文章目录简要题目描述解析dp定义:试填法代码thanks for reading&#xff01;简要 数位dp&#xff0c;天下第一 最重要的应该有两个&#xff1a; 1.状态转移式的确定 2.试填法不断往后模拟 &#xff08;至今是唯一一道数位dp&#xff0c;究竟重要的是啥我其实也没有太多经验 &am…

2021“MINIEYE杯”中国大学生算法设计超级联赛(10)Pty loves string(Border+二维数点)

Pty loves string 建立Border树后&#xff0c;发现可以转化成两个子树中相同点的数量&#xff0c;时间戳转化为连续的区间后相当于有两个数组&#xff0c;每次给两个区间&#xff0c;问区间相同点权的数目。 第一个数组作为区间&#xff0c;第二个数组作为权值。将第一个数组建…

微软推出了Cloud Native Application Bundles和开源ONNX Runtime

微软的Microsoft Connect(); 2018年的开发者大会 对Azure和IoT Edge服务进行了大量更新; Windows Presentation Foundation&#xff0c;Windows Forms和Windows UI XAML Library的开源 以及.NET 基金会会员模型的扩展。但那些只是冰山一角。微软还联合Docker发布了Cloud Native…

不止代码:友好城市(动态规划)

解析 先按左端点排序得到一个右端点的新队列&#xff0c;然后就可以发现&#xff1a; 所有合法的方案都是新队列的一个单调递增队列 然后就转化成了最长上升序列的问题 代码 #include<bits/stdc.h> using namespace std; const int N1e6100; int m,n; struct node{int…

二分图匹配(一)

文章目录什么是二分图&#xff1a;例题&#xff1a;NC111768 CF741C题目描述&#xff1a;题解&#xff1a;代码&#xff1a;二分图最大匹配匈牙利算法算法思想&#xff1a;代码&#xff1a;Knig定理二分图最优匹配KM(Kuhn-Munkres)算法算法思路&#xff1a;具体操作代码&#x…

不止代码:恐狼后卫(ybtoj-区间dp)

文章目录题目描述解析代码thanks for reading!题目描述 一代炉石的眼泪啊 解析 用dp[i][j]表示i与j之间的全部消掉&#xff08;不含两端&#xff09;的最小花费 然后枚举中间最后杀死的狼就行了 本题没有一次AC&#xff0c;因为一开始dp定义成了包含两端&#xff0c;然后因为…

牛客题霸 [二叉树的之字形层序遍历] C++题解/答案

牛客题霸 [二叉树的之字形层序遍历] C题解/答案 题目描述 给定一个二叉树&#xff0c;返回该二叉树的之字形层序遍历&#xff0c;&#xff08;第一层从左向右&#xff0c;下一层从右向左&#xff0c;一直这样交替&#xff09; 例如&#xff1a; 给定的二叉树是{3,9,20,#,#,15…

【.NET Core项目实战-统一认证平台】第九章 授权篇-使用Dapper持久化IdentityServer4...

上篇文章介绍了IdentityServer4的源码分析的内容&#xff0c;让我们知道了IdentityServer4的一些运行原理&#xff0c;这篇将介绍如何使用dapper来持久化Identityserver4&#xff0c;让我们对IdentityServer4理解更透彻&#xff0c;并优化下数据请求&#xff0c;减少不必要的开…

不止代码:生日欢唱(ybtoj-区间dp)

文章目录题目描述解析代码thanks for reading&#xff01;题目描述 解析 这题挺好的 思路&#xff1a;dp[i][j]表示必须把i和j配对&#xff0c;可达到的最大值 首先&#xff1a; dp[i][j]dp[i-1][j-1]a[i]*b[j];然后可以分别尝试把男生或女生往前放弃一段&#xff1a; for(i…

打造自己的.NET Core项目模板

前言每个人都有自己习惯的项目结构&#xff0c;有人的喜欢在项目里面建解决方案文件夹&#xff1b;有的人喜欢传统的三层命名&#xff1b;有的人喜欢单一&#xff0c;简单的项目一个csproj就搞定。。反正就是萝卜青菜&#xff0c;各有所爱。可能不同的公司对这些会有特定的要求…

超好用的C#控制台应用模板

默认模板之缺在工作学习中&#xff0c;我们经常需要创建一些简单的控制台应用(Console App)去验证某个想法&#xff0c;或者作为小工具交付给其他同事。通常我们的选择是 Visual Studio 自带的 Console App 模板&#xff0c;这个经典模板只有预设好的 csproj 文件和空荡荡的 Ma…

不止代码:区间圆数(ybtoj-数位DP)

文章目录题目描述解析理解万岁&#xff01;代码题目描述 解析 一寸山河一寸血 理解万岁&#xff01; 首先&#xff0c;这题统计[l,r]的个数&#xff0c;可以用[1,r]-[1,l-1]来实现 接下来就是如何统计出[1,n]的个数了 首先&#xff0c;用dp[pos][s0]来表示一个二进制pos位有s…

.NET Core 2.2 新增部分功能使用尝鲜

前言美国当地时间12月4日&#xff0c;微软2019开发者大会中发布了一系列的重磅消息&#xff0c;包含了软硬件和开源社区的各种好消息是铺天盖地&#xff0c;作为一名普通的开发者&#xff0c;我第一时间下载了 .NET Core 2.2 的源码&#xff0c;针对发布说明逐条浏览&#xff0…

不止代码:机器分配(动态规划)

题目描述 解析 头疼 什么破题 就是一个dp寻找最优性决策的常规题 但是要输出过程&#xff0c;可以使用递归输出 但是&#xff01; 这题数据的意思是&#xff1a;存在a[i]a[i1]的情况&#xff0c;且在不影响利润的情况下&#xff0c;机器要尽可能的用完 这河里吗 可能是机器多了…

2021中国大学生程序设计竞赛(CCPC)- 网络选拔赛 GCD on Sequence(线段树)

https://blog.csdn.net/qq_45863710/article/details/120121607 对于每个左端点 l 维护尚未确定 v 值的最大的右端点 mx[l] #include<bits/stdc.h>using namespace std; using lllong long; const int N100010; vector<int> vec[N]; int n,a[N],p[N]; ll ans[N]; …

Docker最全教程——从理论到实战(六)

本篇教程持续编写了3个星期左右并且一直在完善、补充具体的细节和实践&#xff0c;预计全部完成需要1到2个月的时间。由于编写的过程中极其费时&#xff0c;并且还需要配合做一些实践&#xff08;有些实践存在一些坑&#xff0c;而且极其费时费事&#xff09;。因此目前产出的速…

.NET Core实战项目之CMS 第八章 设计篇-内容管理极简设计全过程

写在前面上一篇文章.NET Core实战项目之CMS 第七章 设计篇-用户权限极简设计全过程中我带着大家进行了权限部分的极简设计&#xff0c;也仅仅是一个基本的权限设计。不过你完全可以基于这套权限系统设计你的更复杂的权限系统&#xff0c;当然更复杂的权限系统要根据你的业务来进…

2021“MINIEYE杯”中国大学生算法设计超级联赛(2)I love max and multiply(转化)

I love max and multiply Code 代码抄的std #include<bits/stdc.h> using namespace std; using lllong long; template <class Tint> T rd() {T res0;T fg1;char chgetchar();while(!isdigit(ch)) {if(ch-) fg-1;chgetchar();}while( isdigit(ch)) res(res<&…