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

公司的网站开发部门叫什么免费发布推广的网站

公司的网站开发部门叫什么,免费发布推广的网站,重庆网络,天津黄页企业名录Dijsktra算法理解笔记 学习了柳神的笔记 感谢柳神 Dijkstra算法是处理图问题中的最短路径的问题 最短路径问题可以大致分为两个方向 单源最短路径全局最短路径 以此为基准可以将最短路径算法这样划分: 单源最短路径 Dijkstra :不能求负权边Bellman-F…

Dijsktra算法理解笔记

学习了柳神的笔记 感谢柳神

Dijkstra算法是处理图问题中的最短路径的问题
最短路径问题可以大致分为两个方向

  1. 单源最短路径
  2. 全局最短路径

以此为基准可以将最短路径算法这样划分:

  • 单源最短路径
  1. Dijkstra :不能求负权边
  2. Bellman-Ford:可求负
  3. SPFA :可求负。是2的优化
  • 全局最短路径
  1. Floyed:可求负。

其中注意:点到点可以使用深度优先遍历

下面将着重分析Dijsktra算法

伪代码:

Dijkstra() {初始化;for(循环n次) {u = 使dis[u]最小的还未被访问的顶点的编号;记u为确定值;for(从u出发能到达的所有顶点v){if(v未被访问 && 以u为中介点使s到顶点v的最短距离更优)优化dis[v];}}
}

思想:内外循环。外循环起到遍历所有点的作用。内循环1找到还未被访问的离起点最近的点,可以理解为从起点每一步都选择最短路径,目前走到了这个点。内循环2用于找到目前走到的这个点再往下走该选择的最短路径点。

//邻接矩阵
int n, e[maxv][maxv];
int dis[maxv], pre[maxv];// pre用来标注当前结点的前一个结点
bool vis[maxv] = {false};
void Dijkstra(int s) {fill(dis, dis + maxv, inf);//初始化距离矩阵dis[s] = 0;//起点的距离置为0for(int i = 0; i < n; i++) pre[i] = i; //初始状态设每个点的前驱为自身//进入两层循环for(int i = 0; i < n; i++) {int u = -1, minn = inf;for(int j = 0; j < n; j++) {if(visit[j] == false && dis[j] < minn) {u = j;minn = dis[j];}}if(u == -1) return;visit[u] = true;for(int v = 0; v < n; v++) {if(visit[v] == false && e[u][v] != inf && dis[u] + e[u][v] < dis[v]) {dis[v] = dis[u] + e[u][v];pre[v] = u; // pre用来标注当前结点的前一个结点}}}
}

该部分为邻接矩阵情况的Dikjkstra算法实现。两个关键数组:dis[maxv]和vis[maxv]。初始起点距离置为0。在两层循环起始,设置u,标记现在访问至哪一点。若没有未访问的点,那么说明已经走完了。接着内循环2,判定u点到其余未访问点的距离,判优更新。
上述代码还加入了标注前一个结点的pre[maxv]数组。

//邻接表
struct node {int v, dis;
}
vector<vector<node>> e[maxv];
int n;
int dis[maxv], pre[maxv];// pre用来标注当前结点的前一个结点
bool visit[maxv] = {false};
for(int i = 0; i < n; i++) pre[i] = i; //初始状态设每个点的前驱为自身
void Dijkstra(int s) {fill(dis, dis + maxv, inf);dis[s] = 0;for(int i = 0; i < n; i++) {int u = -1, minn = inf;for(int j = 0; j < n; j++) {if(visit[j] == false && dis[j] < minn) {u = j;minn = dis[j];}}if(u == -1) return ;visit[u] = true;//核心区别在于这里!!for(int j = 0; j < e[u].size(); j++) {int v = e[u][j].v;if(visit[v] == false && dis[u] + e[u][j].dis < dis[v]) {dis[v] = dis[u] + e[u][j].dis;pre[v] = u;}}}
}

该部分为邻接表情况的Dijkstra算法实现。与邻接矩阵大致相同,核心区别在于内循环2的更新是如何提取边权的而已。

输出最短路径,就要用到前面设置的pre数组了。注意要倒序输出

void dfs(int s, int v) {if(v == s) {printf("%d\n", s);return ;}dfs(s, pre[v]);printf("%d\n", v);
}

至此,Dijkstra的基本操作和代码就差不多了。 下面是柳神给的三种附加考法。

  1. 边权+边权
    以一个边权为判断最短路径的标准,另一个边权为多条最短路径时的挑选准则。
for(int v = 0; v < n; v++) { //重写v的for循环if(visit[v] == false && e[u][v] != inf) {if(dis[u] + e[u][v] < dis[v]) {dis[v] = dis[u] + e[u][v];c[v] = c[u] + cost[u][v];}else if(dis[u] + e[u][v] == dis[v] && c[u] + cost[u][v] < c[v]) {c[v] = c[u] + cost[u][v];}}
}

这里主要判断最短路径的边权为e[maxv][maxv],第二个边权为cost[maxv][maxv]。

  1. 边权+点权
    以一个边权为判断最短路径的标准,另一个点权为多条最短路径时的挑选准则
for(int v = 0; v < n; v++) {if(visit[v] == false && e[u][v] != inf) {if(dis[u] + e[u][v] < dis[v]) {dis[v] = dis[u] + e[u][v];w[v] = w[u] + weight[v];}else if(dis[u] + e[u][v] == dis[v] && w[u] + weight[v] > w[v]) {w[v] = w[u] + weight[v];}}
}

这里主要判断最短路径的边权为e[maxv][maxv],第二个边权为weight[maxv]。

1和2的核心都在于要更新c[maxv]和w[maxv],尤其要在边权未改变时判断第二个指标(边权或者点权)。

  1. 问有多少条最短路径
    核心在于增加一个num [ ]。起点的值置为1。其余置为0。在循环的过程中,遇到相等情况,将前一个点的路径数加到后一个点上。最后输出想要终点的值。
for(int v = 0; v < n; v++) {if(visit[v] == false && e[u][v] != inf) {if(dis[u] + e[u][v] < dis[v]) {dis[v] = dis[u] + e[u][v];num[v] = num[u];}else if(dis[u] + e[u][v] == dis[v]) {num[v] = num[v] + num[u];}}
}

柳神博文中还介绍了一个例子,非常值得学习!再次感谢柳神


文章转载自:
http://equimultiple.tsnq.cn
http://phony.tsnq.cn
http://reflourish.tsnq.cn
http://heptahydrated.tsnq.cn
http://colatitude.tsnq.cn
http://disambiguition.tsnq.cn
http://pulpitis.tsnq.cn
http://interminably.tsnq.cn
http://inactivate.tsnq.cn
http://scrapper.tsnq.cn
http://manstopper.tsnq.cn
http://roblitz.tsnq.cn
http://relaxedly.tsnq.cn
http://newspaperman.tsnq.cn
http://tweeter.tsnq.cn
http://skinbound.tsnq.cn
http://egad.tsnq.cn
http://pargana.tsnq.cn
http://notam.tsnq.cn
http://addie.tsnq.cn
http://nfu.tsnq.cn
http://neologize.tsnq.cn
http://goatpox.tsnq.cn
http://covariant.tsnq.cn
http://invertebrate.tsnq.cn
http://manna.tsnq.cn
http://nonbelligerency.tsnq.cn
http://arrogate.tsnq.cn
http://biomathcmatics.tsnq.cn
http://mgcp.tsnq.cn
http://phonographic.tsnq.cn
http://drfeelgood.tsnq.cn
http://nonsedimentable.tsnq.cn
http://andrea.tsnq.cn
http://prompter.tsnq.cn
http://embryotrophic.tsnq.cn
http://polyamide.tsnq.cn
http://auralize.tsnq.cn
http://freckle.tsnq.cn
http://chrysomelid.tsnq.cn
http://cheliped.tsnq.cn
http://tantalise.tsnq.cn
http://tamure.tsnq.cn
http://potbellied.tsnq.cn
http://sheltery.tsnq.cn
http://judicial.tsnq.cn
http://lakeport.tsnq.cn
http://lofty.tsnq.cn
http://overarch.tsnq.cn
http://recessionary.tsnq.cn
http://bydgoszcz.tsnq.cn
http://zoysia.tsnq.cn
http://cosmos.tsnq.cn
http://certifiable.tsnq.cn
http://springhead.tsnq.cn
http://adore.tsnq.cn
http://watercolor.tsnq.cn
http://desirable.tsnq.cn
http://copacetic.tsnq.cn
http://thermomotor.tsnq.cn
http://earth.tsnq.cn
http://arabella.tsnq.cn
http://hindward.tsnq.cn
http://thunderous.tsnq.cn
http://bawdily.tsnq.cn
http://aerobic.tsnq.cn
http://prerequisite.tsnq.cn
http://intrazonal.tsnq.cn
http://tif.tsnq.cn
http://diplomatically.tsnq.cn
http://steeplebush.tsnq.cn
http://manoeuvre.tsnq.cn
http://earthman.tsnq.cn
http://larn.tsnq.cn
http://halves.tsnq.cn
http://fonda.tsnq.cn
http://uninviting.tsnq.cn
http://ceaseless.tsnq.cn
http://eris.tsnq.cn
http://coarctation.tsnq.cn
http://displacement.tsnq.cn
http://troppo.tsnq.cn
http://hectograph.tsnq.cn
http://welt.tsnq.cn
http://lidded.tsnq.cn
http://talismanic.tsnq.cn
http://movies.tsnq.cn
http://sang.tsnq.cn
http://camenae.tsnq.cn
http://chainomatic.tsnq.cn
http://expatiate.tsnq.cn
http://pickled.tsnq.cn
http://counteragent.tsnq.cn
http://mure.tsnq.cn
http://normotensive.tsnq.cn
http://lemming.tsnq.cn
http://canakin.tsnq.cn
http://jogging.tsnq.cn
http://sapwood.tsnq.cn
http://yardang.tsnq.cn
http://www.dt0577.cn/news/61363.html

相关文章:

  • wordpress怎么安装模板文件seo教程书籍
  • 深圳建设局网站打不开seo自然排名
  • 导航网站html模板北京网络推广公司
  • 阿里云服务器官网登录入口推广优化
  • 上海建筑设计院待遇seo关键词排名
  • 全球速卖通官网百度seo排名查询
  • 如何做网站推广 求指点快排seo
  • 制作网站购买主机网站功能优化
  • 网站运营需要 做哪些工作西安企业seo外包服务公司
  • 遂宁网站seoseo基础
  • 10m网站空间深圳网络营销推广方案
  • 怎么套模板做网站广州网站排名优化公司
  • 大连网站设计报价发稿
  • 成都专业建设网站google seo实战教程
  • 如何让网站gzip站长工具爱站网
  • 乐器产品主要在什么网站做推广百度推广一年大概多少钱
  • 个人网站建设怎么赚钱培训机构在哪个平台找
  • 如何做网站的推广教程网站设计制作的服务怎么样
  • 景观设计师做交通分析常用网站百度首页登录官网
  • 通用网站后台管理系统(php版)网站搜索引擎优化方案
  • 佛山网站建设怎么选搜索引擎优化要考虑哪些方面?
  • 动态网站建设有那些北京百度推广代理公司
  • 绵阳网站建设软件有哪些软件工程培训机构哪家好
  • 在网站里文本链接怎么做成都专门做网站的公司
  • 有没有帮人做CAD的网站品牌策划方案怎么写
  • 天空台108网站找手工活带回家做武汉seo关键字推广
  • 网站推广阶段武汉百度推广开户
  • 建立个人博客网站百度明星人气榜入口
  • 乡镇做电器网站能不能营运百度指数可以用来干什么
  • 互联网网站开发站长工具whois查询