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

视频网站信息资源建设东莞海外网络推广

视频网站信息资源建设,东莞海外网络推广,网站设计要先做图么,技术开发包括软件开发吗【题目链接】 ybt 1522:网络 OpenJudge 百练 1144:Network 【题目考点】 1. 图论:割点 【解题思路】 每个交换机是一个顶点,如果两地点之间有电话线连接,那么两顶点之间有一条无向边,该图是无向图。 初始时任何地…

【题目链接】

ybt 1522:网络
OpenJudge 百练 1144:Network

【题目考点】

1. 图论:割点

【解题思路】

每个交换机是一个顶点,如果两地点之间有电话线连接,那么两顶点之间有一条无向边,该图是无向图。
初始时任何地点之间都是可以通讯的,也就是说这是一个无向连通图。
如果一个交换机停止工作,导致其它一些地点不能通讯,这样的地点交灾区。那么也就是图中去掉该顶点后,有些顶点之间不再连通(没有路径),那么也就是整个图不再是连通图。这样的点就是割点。
灾区就是割点,统计灾区的数量就是统计割点的数量。
使用tarjan算法求出所有割点,将割点保存在一个set中,或用数组标记哪些顶点是割点,而后统计割点数量。

【题解代码】

解法1:Tarjan算法求割点,使用set保存割点
#include <bits/stdc++.h>
using namespace std;
#define N 105
int n, m;
vector<int> edge[N];//edge[i]:顶点i的邻接点 
int dfn[N], low[N], ts, root;
set<int> cutVer;
void tarjan(int u)
{int child = 0;dfn[u] = low[u] = ++ts;for(int v : edge[u]){if(dfn[v] == 0){tarjan(v);low[u] = min(low[u], low[v]);if(u == root && ++child > 1 || u != root && dfn[u] <= low[v])cutVer.insert(u);}elselow[u] = min(low[u], dfn[v]);} 
}
int main()
{int f, t;while(cin >> n && n != 0){ts = 0;//变量初始化 for(int i = 1; i <= n; ++i)edge[i].clear();memset(dfn, 0, sizeof(dfn));cutVer.clear();while(cin >> f && f != 0)while(cin.get() != '\n'){cin >> t;edge[f].push_back(t);edge[t].push_back(f);}for(int v = 1; v <= n; ++v) if(dfn[v] == 0)tarjan(root = v);cout << cutVer.size() << endl;}return 0;
}
解法2:Tarjan算法求割点,使用标记数组保存割点
#include <bits/stdc++.h>
using namespace std;
#define N 105
int n, dfn[N], low[N], ts, root, ct;
vector<int> edge[N];
bool cutVer[N];//cutVer[i]:i是否是割点
void tarjan(int u)
{int child = 0;dfn[u] = low[u] = ++ts;for(int v : edge[u]){if(dfn[v] == 0){tarjan(v);low[u] = min(low[u], low[v]);if(u == root && ++child > 1 || u != root && dfn[u] <= low[v])cutVer[u] = true;//u是割点 }elselow[u] = min(low[u], dfn[v]); }
} 
int main()
{int f, t;while(cin >> n && n != 0){ts = ct = 0;//变量初始化 for(int i = 1; i <= n; ++i)edge[i].clear();memset(cutVer, 0, sizeof(cutVer));memset(dfn, 0, sizeof(dfn));while(cin >> f && f != 0)while(cin.get() != '\n'){cin >> t;edge[f].push_back(t);edge[t].push_back(f);}for(int v = 1; v <= n; ++v) if(dfn[v] == 0)tarjan(root = v);for(int v = 1; v <= n; ++v) if(cutVer[v])//统计割点数量 ct++;cout << ct << endl;}return 0;
}
http://www.dtcms.com/wzjs/511406.html

相关文章:

  • 做棋牌开发的网站网站seo推广排名
  • 做互联网的网站市场营销渠道
  • 帮人家做网站行业关键词搜索量排名
  • 程序员 做网站 微信公众号 赚钱广州seo顾问
  • 网站验证码是如何做的最近一周的新闻
  • 做网站一定要注册域名吗今日头条国际新闻
  • 徐州市住房建设局网站首页新开店铺怎么做推广
  • 给人做ppt的网站吗软文推广广告
  • 网站建设参考文献自助建站seo
  • 中国能源建设集团网站群seo北京优化
  • 有免费的微网站制作吗网页设计实训报告
  • 淄博外贸网站哪家好搜索引擎有哪些?
  • 广东中南建设有限公司网站快速刷排名的软件最好
  • 小程序网站模板滕州网站建设优化
  • 全国做网站的公司有哪些百度榜单
  • 济源市建设工程管理处网站成都百度业务员电话
  • 网站地图怎么做html国际热点新闻
  • wordpress 更好的主题优化网站关键词排名软件
  • 做网站代码保密协议各城市首轮感染高峰期预测
  • 长沙住房和城乡建设委员会网站saas建站
  • 上饶招聘网站建设公司西安seo专员
  • 蒙阴网站建设女性广告
  • 哔哩哔哩网站4 3比例怎么做广州seo公司
  • 网站树状结构图怎么做做外贸网站的公司
  • 邯郸公司转让系统优化软件
  • 广东网站seo优化报告
  • 完美建设工程有限公司网站网络测试
  • 网站前端切图做多个页面镇江抖音seo
  • 云集网站哪个公司做的网店代运营的套路
  • 怎么做网站和服务器吗移动网站如何优化排名