LeetCode 444. 序列重建(拓扑排序)

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

验证原始的序列 org 是否可以从序列集 seqs 中唯一地重建。
序列 org 是 1 到 n 整数的排列,其中 1 ≤ n ≤ 104
重建是指在序列集 seqs 中构建最短的公共超序列。(即使得所有 seqs 中的序列都是该最短序列的子序列)。
确定是否只可以从 seqs 重建唯一的序列,且该序列就是 org 。

示例 1:
输入:
org: [1,2,3], seqs: [[1,2],[1,3]]
输出:
false
解释:
[1,2,3] 不是可以被重建的唯一的序列,因为 [1,3,2] 也是一个合法的序列。示例 2:
输入:
org: [1,2,3], seqs: [[1,2]]
输出:
false
解释:
可以重建的序列只有 [1,2]。示例 3:
输入:
org: [1,2,3], seqs: [[1,2],[1,3],[2,3]]
输出:
true
解释:
序列 [1,2], [1,3][2,3] 可以被唯一地重建为原始的序列 [1,2,3]。示例 4:
输入:
org: [4,1,5,2,6,3], seqs: [[5,2,6,3],[4,1,5,2]]
输出:
true

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/sequence-reconstruction
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

class Solution {
public:bool sequenceReconstruction(vector<int>& org, vector<vector<int>>& seqs) {int n = org.size();vector<bool> exit(n+1, false);//是否存在vector<vector<int>> g(n+1);//图vector<int> indegree(n+1, 0);//入度for(auto& s : seqs){int from = -1;for(int i = 0; i < s.size(); ++i){if(s[i] <= 0 || s[i] > n) return false;//编号超了exit[s[i]] = true;if(from != -1){g[from].push_back(s[i]);//边indegree[s[i]]++;//入度+1}from = s[i];}}queue<int> q;for(int i = 1; i <= n; ++i){if(!exit[i]) return false;//有的点不存在if(indegree[i]==0)//入度为0的入队q.push(i);}int i = 0;while(!q.empty()){if(q.size() != 1) return false;//选择不唯一int cur = q.front();if(cur != org[i++]) return false;//跟序列不匹配q.pop();for(int i = 0; i < g[cur].size(); ++i){if(--indegree[g[cur][i]] == 0)q.push(g[cur][i]);//入队为0 的入队}}if(i != n) return false;//有环return true;}
};

216 ms 45.2 MB


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

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

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

相关文章

python中的保护对象数据

保护对象数据 查看过着修改对象的属性&#xff08;数据&#xff09;&#xff0c;有2种方法。 直接通过对象名修改 通过方法间接修改 Python中没有像C中public和private这些关键字来区别公有属性和私有属性。它是以属性命名方式来区分&#xff0c;如果在属性名前面加了2个下划…

Highcharts 本地导出图片 Java

下载的 Highcharts-2.3.5.zip 解压后 有 E:\Highcharts\Highcharts-2.3.5\exporting-server\java 目录 提供了Java实现的导出应用。 1&#xff09;安装maven&#xff0c;配置环境变量. &#xff08;http://maven.apache.org/download.cgi&#xff09; 1.jdk 我装的是E:\java\j…

华硕主板如何用u盘启动计算机,华硕主板怎么设置u盘启动都有哪些方法

随着互联网的不断发展&#xff0c;现在使用电脑的机会越来越多了。但是机器难免出故障&#xff0c;或者对于新的电脑需要设置启动。那么华硕主板怎么设置u盘启动。下面由一键工作室介绍一下。华硕主板怎么设置u盘启动华硕主板怎么设置u盘启动 华硕主板设置u盘启动方法1、首先&a…

LeetCode 353. 贪吃蛇(deque+set)

文章目录1. 题目2. 解题1. 题目 请你设计一个 贪吃蛇游戏&#xff0c;该游戏将会在一个 屏幕尺寸 宽度 x 高度 的屏幕上运行。 起初时&#xff0c;蛇在左上角的 (0, 0) 位置&#xff0c;身体长度为 1 个单位。 你将会被给出一个 (行, 列) 形式的食物位置序列。当蛇吃到食物…

python中__del__使用方法

创建对象后&#xff0c;python解释器默认调用__init__()方法。当删除一个对象时&#xff0c;python解释器也会默认调用一个方法&#xff0c;这个方法为__del__()方法。在python中&#xff0c;对于开发者来说很少会直接销毁对象(如果需要&#xff0c;应该使用del关键字销毁)。Py…

html中post和get区别

HTTP协议中的GET和POST方法——二者主要区别如下&#xff1a; 1. get是从服务器上获取数据&#xff0c;post是向服务器传送数据。2. get是把参数数据队列加到提交表单的ACTION属性所指的URL中&#xff0c;值和表单内各个字段一一对应&#xff0c;在URL中可以看到。post是通过HT…

计算机简单故障时的排除方法,电脑简单故障排除解决办法大全

电脑简单故障排除解决办法大全一、电脑罢 工了?听报警声就可以处理故障!在使用电脑的时候&#xff0c;我们会经常遇到开机时电脑黑屏没有反应的情况&#xff0c;普通的电脑用户而对这样的故障实在是无从下手&#xff0c;但是一般电脑会有一个内部自检的功能&#xff0c;如果检…

LeetCode MySQL 1543. Fix Product Name Format(trim去空格+upper/lower大小写)

文章目录1. 题目2. 解题1. 题目 Table: Sales ----------------------- | Column Name | Type | ----------------------- | sale_id | int | | product_name | varchar | | sale_date | date | ----------------------- sale_id is the primary key for …

云计算之路-阿里云上:拔云见日的那一刻,热泪盈眶

当用路过秋天的压力测试工具重现问题的那一刻&#xff0c;热泪盈眶&#xff01;这段时间所承受的一切一涌而出。。。 下面这张图是首次压力测试重现问题时的Windows性能监视器截图&#xff0c;我们对这样的图太熟悉了&#xff0c;当它一出现&#xff0c;就知道问题重现了。红色…

科润酒吧点单系统服务器配置,那些牛逼的酒吧都用什么管理系统?

原标题&#xff1a;那些牛逼的酒吧都用什么管理系统&#xff1f;关于酒吧你是熟悉还是陌生&#xff1f;对酒吧的管理系统&#xff1f;你接触的都有哪些&#xff1f;今天分享一个超大型酒吧的系统解决方案。宁波最大酒吧S86正式营业&#xff0c;视易娱加管理系统助力场所运营&am…

LeetCode 第 32 场双周赛(983/2957,前33.2%)

文章目录1. 比赛结果2. 题目1. LeetCode 5468. 第 k 个缺失的正整数 easy2. LeetCode 5469. K 次操作转变字符串 medium3. LeetCode 5470. 平衡括号字符串的最少插入次数 medium4. LeetCode 5485. 找出最长的超赞子字符串 hard1. 比赛结果 两题选手报道&#xff0c;继续加油&a…

python中的类属性和实例属性

类属性和实例属性&#xff0c;一般我们接触到的就是实例属性&#xff08;对象属性&#xff09;&#xff0c;顾名思义&#xff0c; # 实例属性是对象持有的&#xff0c;不是共享的属性 # 实例属性只有对象能够访问 类属性就是类对象所拥有的属性&#xff0c;它被所有类对象的实…

图片网站用什么服务器好,网站图片与框架放在不同服务器有哪些优缺点

如今很多企业线上发展迅速&#xff0c;对网站的要求也越来越高&#xff0c;因此出现分离式网站架构。怎样理解分离式网站架构呢&#xff1f;理解最简单的一种&#xff0c;即将图片与网站架构分开存放。的确&#xff0c;现在很多企业都采取这样的操作模式&#xff0c;也有可能成…

迭代器是神马东西

一、迭代器用来干嘛的&#xff1f; 本质是指针&#xff0c;用来遍历访问容器中元素的。 STL实现了容器和算法的分离&#xff0c;如何实现的呢&#xff0c;答曰用类模板和函数模板&#xff0c;也可理解为所谓的泛化。那么容器和算法又是怎样结合在一起的呢&#xff0c;答曰迭代器…

python中的类方法和静态方法

类可以有类属性&#xff0c;也可以有类方法&#xff0c;类方法主要是对类属性的封装。是类对象所拥有的方法&#xff0c;需要用修饰器classmethod来标识其为类方法&#xff0c;对于类方法&#xff0c;第一个参数必须是类对象&#xff0c;一般以cls作为第一个参数&#xff08;当…

LeetCode 第 201 场周赛(304/5614,前5.42%)

文章目录1. 比赛结果2. 题目1. LeetCode 5483. 整理字符串 easy2. LeetCode 5484. 找出第 N 个二进制字符串中的第 K 位 medium3. LeetCode 5471. 和为目标值的最大数目不重叠非空子数组数目 medium4. LeetCode 5486. 切棍子的最小成本 hard1. 比赛结果 做出来3题&#xff0c;…

洛克王国进不去 不显示服务器,《洛克王国》FAQ:注册和登陆问题

《洛克王国》FAQ&#xff1a;注册和登陆问题Q&#xff1a;如何登录洛克王国A&#xff1a; 1、 用户在洛克王国首页登录框中&#xff0c;输入自己的QQ号和密码后&#xff0c;点击“登录”按钮即可进入选择服务器界面。2、 洛克王国为用户提供了方便的选择服务器设定&#xff0c;…

出现一次的数字

看了何海涛的日志 他分别解决了一个 两个 三个 出现一次的数字的思路 给人的感觉有一生二 二生三 三生万物的思维 现把自己的感悟写下来 一个 思路很简单 所有数字异或的结果 两个 关键是区别 所有的数字异或的结果同时也是两个出现一次数字异或的结果 记为XORresult<>0 …

python中的__new__概念(工厂

__new__方法实际上在__init__方法之前执行&#xff0c;用于创建类的实例。然而__init__方法负责实例创建后对其进行自定义&#xff0c;__new__方法才是实际上创建并返回实例的方法。 __new__方法的第一个也是最重要的参数是创建实例所需的要的类(按照惯例&#xff0c;命名为cl…

LeetCode 723. 粉碎糖果(模拟)

文章目录1. 题目2. 解题1. 题目 这个问题是实现一个简单的消除算法。 给定一个二维整数数组 board 代表糖果所在的方格&#xff0c;不同的正整数 board[i][j] 代表不同种类的糖果&#xff0c;如果 board[i][j] 0 代表 (i, j) 这个位置是空的。 给定的方格是玩家移动后的游戏…