拓扑排序板子

经过一晚上的不懈努力,创造出了一个很烂的拓扑排序的板子 

这是精简版

using ll = long long;
struct tsort {int n;std::vector<std::vector<int>>g, w;std::vector<int>r, c, dp,f;std::queue<int>q;tsort(int n_) {n = n_;g.resize(n + 1);w.resize(n + 1);r.resize(n + 1);c.resize(n + 1);f.resize(n + 1);dp.resize(n + 1);}void add(int x, int y, int v = 0) {//有向边g[x].push_back(y);//值w[x].push_back(v);//入度r[y]++;//出度c[x]++;}ll all(int x=0, ll M=0, int s=0) {ll ans = 0;if(s)q.push(s);else {for (int i = 1; i <= n; i++) {//if (x && i != x) {dp[i] = -1e9;if (r[i] == 0)q.push(i);}else if (M&&r[i] == 0) {q.push(i);f[i] = 1;}}}while (!q.empty()) {//int x = q.front();//q.pop();//for (int i = 0; i < g[x].size(); i++) {//int j = g[x][i];//if(M)f[j] = (f[j] + f[x]) % M;if(s)dp[j] = std::max(dp[j], dp[x] + w[x][i]);r[j]--;//if (r[j] == 0) {if (M&&c[j] == 0) {ans = (ans + f[j]) % M;continue;}q.push(j);//}}}return ans;}
};int main() {int n, m;std::cin >> n >> m;tsort t(n);while (m--) {int x, y;std::cin >> x >> y;t.add(x, y);}std::cout << t.all(0, 80112002,0);return 0;
}

传入第一个参数用于去除其它重复的入度为0的路径,传入第三个参数,用于计算从该点到其它的点的最长路径,两者通常结合在一起使用,传入第二个参数,用于计算入度为0出度为0的路径有多少个,第二个参数是模数.其它两个参数要设为0

下面这个是不省略的版本

using ll = long long;
struct tsort {int n;std::vector<std::vector<int>>g, w;std::vector<int>r, c, dp,f;std::queue<int>q;tsort(int n_) {n = n_;g.resize(n + 1);w.resize(n + 1);r.resize(n + 1);c.resize(n + 1);f.resize(n + 1);dp.resize(n + 1);}void add(int x, int y, int v = 0) {//有向边g[x].push_back(y);//值w[x].push_back(v);//入度r[y]++;//出度c[x]++;}//固定起点,去重bool dedup(int x) {//如果起点入度不为0,返回false//if (r[x])return false;for (int i = 1; i <= n; i++) {//if (i != x) {dp[i] = -1e9;if (r[i] == 0)q.push(i);}}while (!q.empty()) {//int x = q.front();//q.pop();//for (int i = 0; i < g[x].size(); i++) {//int j = g[x][i];//r[j]--;//if (r[j] == 0)q.push(g[x][i]);//}}return true;}//计算所有入度为0,出度为0的路径,M是模数ll pathsum(ll M= 80112002) {ll ans = 0;for (int i = 1; i <= n; i++) {if (r[i] == 0) {q.push(i);f[i] = 1;}}while (!q.empty()) {int x = q.front();q.pop();for (int i = 0; i < g[x].size(); i++) {int j = g[x][i];r[j]--;f[j] = (f[j] + f[x]) % M;if (r[j] == 0) {if (c[j] == 0) {ans = (ans + f[j]) % M;continue;}q.push(j);}}}return ans;}void work(int s) {q.push(s);while (!q.empty()) {int x = q.front();q.pop();//该点所对应的所有路径for (int i = 0; i < g[x].size(); i++) {dp[g[x][i]] = std::max(dp[g[x][i]], dp[x] + w[x][i]);if (!--r[g[x][i]])q.push(g[x][i]);}}}};int main() {int n, m;std::cin >> n >> m;tsort t(n);while (m--) {int x, y;std::cin >> x >> y;t.add(x, y);}std::cout << t.all(0, 80112002,0);return 0;
}

这个板子就略显臃肿

当然,如果你只想计算一条合理的拓扑序列,你可以将所有参数设为0,且将入度为0的点放入答案即可.

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

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

相关文章

Java内存详解

内存区域、内存模型 内存区域&#xff1a;即运行时数据区域&#xff0c;指JVM对于不同类型数据在内存中的存储方式内存模型&#xff08;JMM&#xff1a;Java Memory Model&#xff09;&#xff1a;定义了线程与主内存之间的抽象关系&#xff0c;即JVM在内存中的工作方式&#…

微信小程序如何使用weui组件库?

一、方法一&#xff1a;通过npm安装 通过npm构建方式引入weui组件库 &#xff08;找到.eslintrc.js 右键&#xff0c;在内件终端打开&#xff09;打开命令提示符后&#xff0c;输入 &#xff08;1&#xff09;npm init -y来快速生成一个默认的package.json文件 &#xff08;…

鸿蒙 装饰器@builder 使用中的问题 以及解决方案

builder装饰器 一 介绍Builder装饰器&#xff1a;自定义构建函数二 问题点三 解决方法四 仓库地址 一 介绍Builder装饰器&#xff1a;自定义构建函数 用于填充UI组件 开发者可以将重复使用的UI元素抽象成一个方法&#xff0c;在build方法里调用。 根据场景分类 组件内自定义构…

设计非递归算法,编程:在二叉排序树中,打印关键码a, b的公共祖先。注:例,若a是b的祖先,则a不算作公共祖先。反之亦然。

二叉排序树&#xff1a; 代码&#xff1a; #include <iostream> using namespace std;// 定义二叉树节点结构 typedef struct BTNode {char show;struct BTNode* left;struct BTNode* right; } BTNode;// 非递归插入节点的函数 BTNode* insertNode(BTNode* root, char k…

Leetcode - 周赛397

目录 一&#xff0c;3146. 两个字符串的排列差 二&#xff0c;3147. 从魔法师身上吸取的最大能量 三&#xff0c;3148. 矩阵中的最大得分 四&#xff0c;3149. 找出分数最低的排列 一&#xff0c;3146. 两个字符串的排列差 本题就是求同一个字符在两个字符串中的下标之差的…

QCustomPlot的了解

&#xff08;一&#xff09;QCustomPlot常见属性设置、多曲线绘制、动态曲线绘制、生成游标、矩形放大等功能实现-CSDN博客 关键代码&#xff1a; QT core gui printsupport 使用上面文章中的代码跑起来的程序效果图&#xff1a; 我的学习过程&#xff1a; 最开始初…

家用充电桩远程监控安全管理系统解决方案

家用充电桩远程监控安全管理系统解决方案 在当今电动汽车日益普及的背景下&#xff0c;家用充电桩的安全管理成为了广大车主关注的重点问题。为了实现对充电桩的高效、精准、远程监控&#xff0c;一套完善的家用充电桩远程监控安全管理系统解决方案应运而生。本方案旨在通过先…

如何去除字符串两侧的空白字符?

TRIM函数会去掉字符串左侧和右侧的空格&#xff0c;语法是&#xff1a;TRIM(字符串) excel中&#xff0c;TRIM函数能去掉字符串左侧和右侧的空格&#xff0c;它的ASCII码是32。 以下设定一个字符串组合&#xff0c;它的第一个字符中空格&#xff0c;最后一个字符是换行符 &q…

Python专题:十七、做个小游戏

终端小游戏 1、根据题库内容出单选题 2、提示作答&#xff0c;并给结果 思路 列表 保存题目 字典 保存题干&#xff0c;选项和答案 遍历 题目列表用于展示 input函数 等待用户输入 判断输入&#xff0c;并继续提示 计算正确率并打印 题库…

oracle不得不知道的sql

一、oracle 查询语句 1.translate select translate(abc你好cdefgdc,abcdefg,1234567)from dual; select translate(abc你好cdefgdc,abcdefg,)from dual;--如果替换字符整个为空字符 &#xff0c;则直接返回null select translate(abc你好cdefgdc,abcdefg,122)from dual; sel…

【Linux进程通信 —— 管道】

Linux进程通信 —— 管道 进程间通信介绍进程间通信的概念进程间通信的目的进程间通信的本质进程间通信的分类 管道什么是管道匿名管道匿名管道的原理pipe用fork来共享管道原理站在文件描述符角度-深度理解管道站在内核角度-管道本质管道读写规则管道的特点管道的四种特殊情况管…

2024软件测试必问的常见面试题1000问!

01、您所熟悉的测试用例设计方法都有哪些&#xff1f;请分别以具体的例子来说明这些方法在测试用例设计工作中的应用。 答&#xff1a;有黑盒和白盒两种测试种类&#xff0c;黑盒有等价类划分法&#xff0c;边界分析法&#xff0c;因果图法和错误猜测法。白盒有逻辑覆盖法&…

三子棋游戏

1、实现三子棋 test.c //测试游戏的逻辑 game.c //游戏代码的实现 game.h //游戏代码的声明&#xff08;函数声明&#xff0c;符号定义&#xff09; 1、 在主函数里实现&#xff0c;首先有个界面&#xff0c;让玩家选择是否玩游戏。上来就先打印菜单&#xff0c;用do ... …

优秀测试的核心能力!2招高效定位分析BUG!

之所以写这一篇文章&#xff0c;是突然想起来曾经在测试过程中被开发嘲讽过&#xff0c;事情是这样的&#xff0c;当时发现了一个疑似前端的Bug就草草提交到了禅道&#xff0c;结果刚来的女前端看到了就有点生气地问我为啥不查清到底是前后端问题就直接派给她前端了&#xff0c…

【python量化交易】—— Alpha选股策略 - Qteasy自定义交易策略【附源码】

使用qteasy创建并回测Alpha选股交易策略 使用qteasy创建并回测Alpha选股交易策略策略思想第一种自定义策略设置方法&#xff0c;使用持仓数据和选股数据直接生成比例交易信号PS信号&#xff1a;第二种自定义策略设置方法&#xff0c;使用PT交易信号设置持仓目标&#xff1a;第三…

【数组中重复的数据】leetcode,python

和上题一样&#xff0c;【找到所有数组中消失的数字】 换个判断条件就行 class Solution:def findDuplicates(self, nums: List[int]) -> List[int]:nlen(nums)for i in nums:x(i-1)%nnums[x]n#只需要替换条件即可return [i1 for i,num in enumerate(nums) if num>(2*n)…

第十四节 huggingface的trainner的_inner_training_loop函数源码解读

文章目录 前言一、self.get_train_dataloader()函数1、self.get_train_dataloader()函数完整源码2、dataset与dataloadera、dataset与dataloader来源b、dataset与dataloader处理c、self._get_collator_with_removed_columns()函数获得collate_fn3、self._get_train_sampler()采…

grep命令总结

grep命令可以是根据特定条件过滤文本内容。 查看含义指定字符的行 这里就是过滤含有root的行 [rootlu-k8s-master133 ~]# grep root /etc/passwd root:x:0:0:root:/root:/bin/bash operator:x:11:0:operator:/root:/sbin/nologin查看开头含有指定字符的行 这里就是使用^r 代…

算法随想录第八天打卡|344.反转字符串,541. 反转字符串II, 卡码网:54.替换数字, 151.翻转字符串里的单词,卡码网:55.右旋转字符串

344.反转字符串 建议&#xff1a; 本题是字符串基础题目&#xff0c;就是考察 reverse 函数的实现&#xff0c;同时也明确一下 平时刷题什么时候用 库函数&#xff0c;什么时候 不用库函数 题目链接/文章讲解/视频讲解&#xff1a;代码随想录 Python class Solution:def reve…

海外云手机的运作原理和适用场景

海外云手机是一种基于云计算技术的虚拟手机服务&#xff0c;通过将手机操作系统和应用程序托管在远程服务器上&#xff0c;实现用户可以通过互联网连接来使用和管理手机功能&#xff0c;而无需实际拥有物理手机。以下是有关海外云手机的相关信息&#xff1a; 海外云手机的运作原…