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

网站推广的营销策划方案营销型网站知识

网站推广的营销策划方案,营销型网站知识,成全视频免费观看在线看天黑黑,网站后台修改内容看不见了有向图的强连通分量 定义 强连通分量(Strongly Connected Components, SCC) 是图论中的一个概念,在一个有向图中,如果存在一个子图,使得该子图中的任意两个顶点都相互可达(即从任何一个顶点出发都可以到达该子图中的其他任何顶点…

有向图的强连通分量

定义

强连通分量(Strongly Connected Components, SCC) 是图论中的一个概念,在一个有向图中,如果存在一个子图,使得该子图中的任意两个顶点都相互可达(即从任何一个顶点出发都可以到达该子图中的其他任何顶点),那么这个子图就称为一个强连通分量。注意,这里的“子图”指的是原图的一个极大子集,也就是说,它不能被扩展成更大的满足上述条件的集合。

运用情况

  1. 网络分析:在互联网路由、社交网络分析中识别紧密相连的群体。
  2. 编译器优化:在程序流图中找到可以独立优化的部分。
  3. 数据挖掘:在有向无环图(DAG)中寻找循环依赖。
  4. 游戏设计:确定游戏中不同关卡之间的关系。

注意事项

  • 强连通分量的求解通常需要考虑图的大小和复杂度,对于大规模图可能需要高效算法。
  • 非强连通的有向图可以被分解为其强连通分量的集合,这些分量之间形成一个有向无环图(DAG),这有助于理解图的结构。

解题思路

  1. Kosaraju's 算法:这是一种两遍深度优先搜索算法。首先对原图进行一次深度优先搜索,记录下每个顶点的完成时间;然后构建原图的转置图,并按照第一次DFS的完成时间逆序遍历顶点,对转置图进行第二次深度优先搜索。每次新的DFS遍历开始时找到的顶点集合就是一个强连通分量。
  2. Tarjan's 算法:这是另一种使用深度优先搜索的方法,但是它是单遍的。它利用低链接值(low-link value)的概念来发现强连通分量。

AcWing 367. 学校网络

题目描述

367. 学校网络 - AcWing题库

运行代码

#include <cstring>
#include <iostream>
using namespace std;
const int N = 110, M = N * N;
int n;
int h[N], e[M], ne[M], idx;
int dfn[N], low[N], timestamp;
int din[N], dout[N];
int scc_cnt, id[N];
int stk[N], top;
bool in_stk[N];void add(int a, int b)
{e[idx] = b, ne[idx] = h[a], h[a] = idx ++ ;
}void tarjan(int u)
{dfn[u] = low[u] = ++ timestamp;stk[ ++ top] = u, in_stk[u] = true;for(int i = h[u]; ~i; i = ne[i]){int j = e[i];if(!dfn[j]){tarjan(j);low[u] = min(low[u], low[j]);}else if(in_stk[j])low[u] = min(low[u], dfn[j]);}if(low[u] == dfn[u]){int y;scc_cnt ++ ;do{y = stk[top -- ];in_stk[y] = false;id[y] = scc_cnt;}while(y != u);}
}int main()
{memset(h, -1, sizeof h);cin >> n;for(int i = 1; i <= n; i ++ ){int t;while(cin >> t, t) add(i, t);}for(int i = 1; i <= n; i ++ ) if(!dfn[i])tarjan(i);for(int i = 1; i <= n; i ++ )for(int j = h[i]; ~j; j = ne[j]){int k = e[j];int a = id[i], b = id[k];if(a != b){dout[a] ++ ;din[b] ++ ;}}int a = 0, b = 0;    for(int i = 1; i <= scc_cnt; i ++ ){if(!din[i]) a ++ ;if(!dout[i]) b ++ ;}cout << a << endl;if(scc_cnt == 1) puts("0");else cout << max(a, b) << endl;return 0;
}

代码思路

  1. 初始化图结构: 使用邻接表表示有向图,h[]数组存储每个顶点的首条边的索引,e[]数组存储边的目的顶点,ne[]数组存储每条边的下一条边的索引。

  2. 深度优先搜索(DFS):

    • 使用dfn[]数组存储顶点的访问顺序(发现时间)。
    • 使用low[]数组存储能够回溯到的最早发现时间。
    • 使用stk[]数组和in_stk[]数组跟踪DFS栈中的顶点,用于检测强连通分量。
    • tarjan()函数递归地执行DFS,并更新low[]数组,当low[u] == dfn[u]时,表明找到了一个新的强连通分量。
  3. 强连通分量后处理:

    • 计算每个强连通分量的入度(din[])和出度(dout[])。
    • 统计没有入度或没有出度的强连通分量数量,即潜在的入口点或出口点。
  4. 输出结果:

    • 输出没有入度的强连通分量数量作为潜在入口点数。
    • 如果整个图是一个强连通分量,则输出0,否则输出入口点和出口点的最大数量。

改进思路

  1. 内存效率:可以使用vector代替数组来动态分配空间,减少不必要的预分配。

  2. 代码清晰性:分离图的构建、强连通分量检测和后处理逻辑,增加可读性和可维护性。

  3. 异常处理:增加输入验证,确保输入格式正确,避免潜在的运行时错误。

  4. 性能优化:考虑使用更高效的容器类型,如std::unordered_map来加速查找操作(虽然在这个特定问题上可能不会显著影响性能)。

  5. 多源点和多汇点检测:直接输出没有入度或出度的SCC数量可能不足以描述图的特性,可以考虑输出具体的SCC信息。  

http://www.yayakq.cn/news/406939/

相关文章:

  • 网站开发主管做网站前端网址可以自己写吗
  • 网站制作公司 沈阳软件开发app制作下载
  • 网站开发视频转码招聘海报模板在线制作免费
  • app推广平台网站wordpress 开放注册
  • 农村建设自己的网站pr效果做的好的网站有哪些
  • 做网站个人怎么签合同临沂企业网站建设
  • 做最优秀的自己演讲视频网站填写网站备案信息
  • 做文交所的都有哪些网站常州免费做网站
  • 英文网站 正文字体大小wordpress果酱二维码
  • 网站制作 天津漯河网站建设哪家
  • 静态网站开发百科90设计网站手机版
  • 做吃的教程网站网站浮动窗口怎么设置
  • 网站建设毕业设计综述轮胎 东莞网站建设
  • 旅游网站源代码模板国外做做网站
  • 临淄区住房和城乡建设局网站世纪兴网站建设
  • 上海交通大学网站建设与管理3设计制作的广告公司
  • 佛山做礼物的网站网页设计与制作课件清华大学
  • 成都市网站建设哪家好wordpress 调用小工具栏
  • 沈阳建站价格手机上可以创建网站吗
  • 涿州做网站验证码平台 wordpress
  • 网站导航栏最多可以做几个专业网站设计力荐亿企邦
  • 建湖营销型网站建设工作室腾讯微信官网
  • No餐饮网站建设wordpress中文杂志主题
  • 用什么做网站的访问量统计小清新网站源码
  • 淄博建设企业网站东莞建设工程信息网
  • 做网站能不备案么wordpress怎么修改右上角的内容
  • 制作网站开发用的图片海南省建设执业资格管理中心网站
  • 海南省建设人力资源网站湖南竞网做网站好吗
  • 济南 域名注册 网站建设网站建设教程学校
  • 工作做ppt课件的网站它是企业整体