当前位置: 首页 > news >正文

DAG 的深度优先搜索标记

/*==================================================*\
| DAG 的深度优先搜索标记
| INIT: edge[][] 邻接矩阵 ; pre[], post[], tag 全置 0;
| CALL: dfstag(i, n); pre/post: 开始 / 结束时间
\*==================================================*/
int edge[V][V], pre[V], post[V], tag;
void dfstag( int cur, int n)
{ // vertex: 0 ~ n-1
pre[cur] = ++tag;
for ( int i=0; i<n; ++i) if (edge[cur][i]) {
if (0 == pre[i]) {
printf( "Tree Edge!\n" );
dfstag(i, n);
} else {
if (0 == post[i]) printf( "Back Edge!\n" );
else if (pre[i] > pre[cur])
printf( "Down Edge!\n" );
else printf( "Cross Edge!\n" );
}
}
post[cur] = ++tag;
}
http://www.lryc.cn/news/168726.html

相关文章:

  • 网络存储解决方案:选择与配置
  • java中BigDecimal除法运算指定小数点保留位数和取舍规则
  • 车联网远程监控管理提升车辆调度效率,实现高效运营
  • 数据治理-数据建模和设计
  • 博客系统(升级(Spring))(四)(完)基本功能(阅读,修改,添加,删除文章)(附带项目)
  • 常用的辅助类(必会)
  • Java常用类之 String、StringBuffer、StringBuilder
  • linux在所有文件中查找某一个字符串
  • WebSocket vs SSE: 实时数据推送到前端的选择与实现(详细)
  • Redis从入门到精通(二:数据类型)
  • 基于SSM的珠宝首饰交易平台
  • 4款视频号数据分析平台!
  • 【系统架构】什么是集群?为什么要使用集群架构?
  • Java手写拓扑排序和拓扑排序应用拓展案例
  • 练习:使用servlet显示试卷页面
  • 视频监控系统/视频云存储EasyCVR接入国标GB28181设备无法播放设备录像,是什么原因?
  • 四叶草clover配置工具:Clover Configurator for Mac
  • 计算机网络第四章——网络层(中)
  • 时序分解 | MATLAB实现基于小波分解信号分解分量可视化
  • VMware虚拟化环境搭建
  • Jenkins :添加node权限获取凭据、执行命令
  • 如何实现不同MongoDB实例间的数据复制?
  • 微服务保护-隔离
  • 报错:appium AttributeError: ‘NoneType‘ object has no attribute ‘to_capabilities‘
  • MFC - 一文带你从小白到项目应用(全套1)
  • (2596. 检查骑士巡视方案leetcode,经典深搜)-------------------Java实现
  • Docker 部署 Bitwarden RS 服务
  • python与mongodb交互-->pymongo
  • 【网络】计算机网络基础
  • (1)输入输出函数:cin和cout(2)数学函数:sqrt、pow、sin、cos、tan等