洛谷 2921 记忆化搜索 tarjan 基环外向树

洛谷 2921 记忆化搜索 tarjan


传送门 (https://www.luogu.org/problem/show?pid=2921)


做这题的经历有点玄学,,起因是某个random题的同学突然发现了一个0提交0通过的题目,然后就引发了整个机房的兴趣,,然后,,就变成了16提交7通过,,

初看上去这题目就是记忆化搜索,但是环的存在使得普通的记忆化会导致漏解,继续观察发现整张图为n个点n条边,即是多个基环外向树,使用tarjan找到图中的环,显然可知,对于环上一点,能取到的最大值是环的长度,对于环外一点,能取到的最大值是它走到环的长度加上环长,之后采用记忆化搜索或dp即可得解

Warning:

  1. 从样例可以显然发现,存在自环
  2. 开始写tarjan时错误的理解了low数组的含义,将其与from数组混淆

int

#include <cstdio>
#include <cstring>
#include <algorithm>const int maxn = 100000 + 100;
int next[maxn];
int dfn[maxn], low[maxn], size[maxn], sta[maxn];
int from[maxn];
int vis[maxn];
int stackTop = 0;
int tim = 0;
int n;
int ans[maxn];void tarjan(int x) {tim++;stackTop++;sta[stackTop] = x;dfn[x] = low[x] = tim;vis[x] = 1;if (!dfn[next[x]]) {tarjan(next[x]);low[x] = std :: min(low[next[x]], low[x]);} else if (vis[next[x]]) {low[x] = std :: min(low[x], dfn[next[x]]);}if (low[x] == dfn[x]) {while (sta[stackTop] != x) {size[x]++;from[sta[stackTop]] = x;vis[sta[stackTop]] = 0;stackTop--;}vis[x] = 0;stackTop--;size[x]++;from[x] = x;}
}void dfs(int x) {if (ans[x] > 0) return;if (from[x] != x || size[x] > 1) {ans[x] = size[from[x]];return;} else if (next[x] == x) {ans[x] = 1;return;} else {dfs(next[x]);ans[x] = 1 + ans[next[x]];}
}int main () {scanf("%d", &n);for (int i = 1; i <= n; i++) {scanf("%d", &next[i]);}for (int i = 1; i <= n; i++) {if (!dfn[i]) tarjan(i);}//for (int i = 1; i <= n; i++) //     printf("%d\n", from[i]);for (int i = 1; i <= n; i++)if (ans[i] == 0) dfs(i);for (int i = 1; i <= n; i++) printf("%d\n", ans[i]);return 0;
}

转载于:https://www.cnblogs.com/CtsNevermore/p/6018135.html

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

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

相关文章

单片机位寻址举例_单片机学习:51单片机寻址方式详解

51单片机是对所有兼容Intel 8031指令系统的单片机的统称。该系列单片机的始祖是Intel 8031单片机&#xff0c;后来随着Flash rom 技术的发展&#xff0c;8031单片机取得了长足的发展&#xff0c;成为了应用最广泛的8位单片机之一。51单片机是基础入门的一个单片机&#xff0c;并…

网络知识:LAN、WAN、WLAN相关知识介绍

今天给大家介绍一下LAN、WAN、WLAN相关知识&#xff0c;希望对大家能有所帮助&#xff01; 一、什么是lan、wan和wlan口的区别&#xff1f; 很多朋友对lan口与wan及wlan的用途了解不清楚&#xff0c;尤其是在做路由器桥接时&#xff0c;wan口与lan的连接与设置容易弄混。 1、LA…

jps

jps位于jdk的bin目录下&#xff0c;其作用是显示当前系统的java进程情况&#xff0c;及其id号。 jps相当于Solaris进程工具ps。不象”pgrep java”或”ps -ef grep java”&#xff0c;jps并不使用应用程序名来查找JVM实例。因此&#xff0c;它查找所有的Java应用程序&#xff0…

SQL

修改表的列名&#xff1a; exec sp_rename testtable.id,ID,column 根据传入时间删除同一天的记录 1、 delete InventoryMovementsTemp where DateDiff(DD,TrnDate ,1/11/2013)0 2、 where convert(varchar(10),TrnDate,126)’’213-01-10 2、 where trndate>’2013-01-10’…

后端技术:mybatis中resultMap用法示例笔记

1、概念resultMap属于mybatis返回操作结果的一个标签&#xff0c;可以用来映射select查询出来结果的集合&#xff0c;主要作用是将实体类中的字段与数据库表中的字段进行关联映射。并且支持复杂的返回结果类型。2、使用场景2.1 属性映射当数据库字段和项目中的实体属性不一致时…

将mysql服务移除_怎么将mysql服务移除?

将mysql服务移除的方法&#xff1a;1、进入“控制面板->程序->卸载或更改程序”&#xff0c;删除mysql程序&#xff1b;2、删除MySQL文件夹下的【my.ini】文件&#xff0c;如果备份好&#xff0c;可以直接将文件夹全部删除 &#xff1b;3、进入注册表&#xff0c;将相关M…

程序人生:程序员的9个层次,你属于哪个层次

目录 第一级&#xff1a;糟糕的程序员 第二级&#xff1a;菜鸟级程序员 第三级&#xff1a;码农 第四级&#xff1a;普通程序员 第五级&#xff1a;中级程序员 第六级&#xff1a;骨干程序员 第八级&#xff1a;著名程序员 第九级&#xff1a;祖师爷级别 . 第一级&#xff1a;糟…

lsof -i:port 的作用

lsof&#xff08;list open files&#xff09;是一个列出当前系统打开文件的工具。在linux环境下&#xff0c;任何事物都以文件的形式存在&#xff0c;通过文件不仅仅可以访问常规数据&#xff0c;还可以访问网络连接和硬件。如TC和UDP等&#xff0c;系统在后台都为该应用程序分…

SpringBoot定时任务实现的两种方式介绍

今天给大家介绍SpringBoot定时任务实现的几种方式&#xff0c;希望对大家能有所帮助&#xff01;1、SpringTask 用法框架介绍&#xff1a;SpringTask是Spring自带的轻量级定时任务工具&#xff0c;相比于Quartz使用更加简单方便&#xff0c;并且不需要不需要引入其他依赖即可使…

mvc调用mysql存储过程_使用.NET MVC +EF调用oracle的存储过程

题记&#xff1a;需求如题&#xff0c;在网上搜索了一下&#xff0c;没有特别贴合我需求的资料&#xff0c;只好自己摸索&#xff0c;东拼西凑了解了一点东西慢慢尝试做了出来。难点&#xff1a;.NET是微软产品&#xff0c;主要支持Sql Server数据库&#xff0c;对于Oracle的数…

Oracle12c:安装后新建用户及其默认表空间,并创建表测试

环境&#xff1a;操作系统&#xff1a;Windows Server2008 R2 X64 Oracle版本&#xff1a;12c 如何安装&#xff1f; -- oracle 12c在oracle linux 6.6 x64上的安装 -- Windows x64位下完美安装winx64_oracle_12c_database 如何使用DataBase Cofiguration Assistant 创建数据库…

数据库:Redis相关知识梳理

1、数据类型string&#xff08;字符串&#xff09;&#xff1a;最基本的k-v存储 &#xff0c;适合验证码、配置信息等list&#xff08;列表&#xff09;&#xff1a;适合有序/固定的列表。比如行政区、字典表、消息队列等。set&#xff08;集合&#xff09;&#xff1a;支持交集…

python线性回归分析看相关性_机器学习入门-相关分析之简单线性回归

一.什么是机器学习&#xff1f;简单来说&#xff0c;机器学习是一类算法的总称&#xff0c;这些算法企图从大量历史数据中挖掘出其中隐含的规律&#xff0c;并用于预测或者分类&#xff0c;更具体的说&#xff0c;机器学习可以看作是寻找一个函数&#xff0c;输入是样本数据&am…

Android Listview 性能优化

首先我一般使用的适配器是BaseAdapter,其中有两个方法最主要,分别是: getCount,getView,在对Listview 进行优化的时候,首先使用 convertview 和viewHolder 配合进行优化,使用convertview的母的是控件复用,从而加到减少内存的使用,使用viewHolder 的是减少findbyid 的次数.但是在…

前端:JS实现数组去重常用的六种方法介绍

今天给大家分享JS实现数组去重常用的六种方法&#xff0c;希望对大家能有所帮助&#xff01;定义变量let arr [20,6,13,20,100,8,13,11]; let newArr [];1、两层循环去重 for(let i 0;i < arr.length;i){for(let j i 1;j < arr.length;j){if(arr[i] arr[j]){arr.sp…

python自定义colorbar_python可视化 matplotlib画图使用colorbar工具自定义颜色

python matplotlib画图使用colorbar工具自定义颜色 colorbar(draw colorbar without any mapple/plot)自定义colorbar可以画出任何自己想要的colorbar&#xff0c;自由自在、不受约束&#xff0c;不依赖于任何已有的图(plot/mappable)。这里使用的是mpl.colorbar.ColorbarBase类…

不能读取文件“itunes.library.itl”因为它是由更高级别的itunes所创建的

转自&#xff1a;https://zhidao.baidu.com/question/80796363.html 是因为你安装过高版本的后又装你版本的itunes. 你在电脑上搜索所有硬盘上的itunes library.itl这个文件.搜到就删了&#xff0c;而且搜索里选择“高级选项”除了区分大小写其它几个都钩上。这样注消下&#x…

路由器:什么是软路由,看完本篇文章你就懂了

今天小编给大家介绍一下软路由具体是什么&#xff0c;有什么实际用途&#xff0c;看完本篇你就懂了&#xff01; 一、软路由与硬路由概念介绍 硬路由&#xff1a;目前我们家里普遍使用的路由器&#xff0c;有厂家提供整体的解决方案&#xff0c;包括处理器、电源供应、嵌入式软…

c#form+mysql储存读取图片_C#从SQL server数据库中读取l图片和存入图片

本实例主要介绍如何将图片存入数据库。将图片存入数据库,首先要在数据库中建立一张表,将存储图片的字段类型设为Image类型,用FileStream类、BinaryReader把图片读成字节的形式,赋给一个字节数组,然后用ADO.SqlCommand对象的ExecuteNonQuery()方法来把数据保存到数据库中。主要代…