摘要: 算法一:暴力枚举 阅读全文
posted @ 2017-04-18 20:22 Bennettz 阅读(764) 评论(0) 推荐(0) 编辑
摘要: 原理:队列+松弛操作 将源点加入队尾,每一步读取队头顶点u,并将队头顶点u出队(记得消除标记);将与点u相连的所有点v进行松弛操作,如果能更新距离(即令d[v]变小),那么就更新,另外,如果点v没有在队列中(打个标记),那么要将点v入队,如果已经在队列中了,那么就不用入队 以此循环,直到队空为止就完 阅读全文
posted @ 2017-04-18 15:27 Bennettz 阅读(512) 评论(0) 推荐(0) 编辑
摘要: ①先取一点v[0]作为起始点,初始化dis[i],d[i]的值为v[0]到其余点v[i]的距离w[0][i],如果直接相邻初始化为权值,否则初始化为无限大; ②将v[0]标记,vis[0] = 1(vis一开始初始化为0); ③找寻与v[0]相邻的最近点v[k],将v[k]点记录下来,v[k]与v[ 阅读全文
posted @ 2017-04-18 11:01 Bennettz 阅读(220) 评论(0) 推荐(0) 编辑
摘要: Floyd算法是一个经典的动态规划算法。用通俗的语言来描述的话,首先我们的目标是寻找从点i到点j的最短路径。从动态规划的角度看问题,我们需要为这个目标重新做一个诠释(这个诠释正是动态规划最富创造力的精华所在) 从任意节点i到任意节点j的最短路径不外乎2种可能,1是直接从i到j,2是从i经过若干个节点 阅读全文
posted @ 2017-04-18 09:17 Bennettz 阅读(185) 评论(0) 推荐(0) 编辑
摘要: 递归的本质是通过栈来保存状态,然后再次调用自己进入新的状态,然后函数返回的时候回到上次保存的状态。 如果一个函数中所有递归形式的调用都出现在函数的末尾,我们称这个递归函数是尾递归的。当递归调用是整个函数体中最后执行的语句且它的返回值不属于表达式的一部分时,这个递归调用就是尾递归。尾递归函数的特点是在 阅读全文
posted @ 2017-04-18 08:33 Bennettz 阅读(1684) 评论(0) 推荐(0) 编辑