求最小转弯路径(Minimizing Turns)|树

这个问题来自这里:

Paste_Image.png

上图中两个点之间存在多个路径,请求出转弯最小的路径。

思路1:
突然联想到爬楼梯的问题,用动态规划加递归,有点像图的DFS和树的前序遍历。不过这里只是输出了最短的转弯数,并没有输出路径,要输出路径的另外一个方法,找到从A到B的所有路径带转弯数(这个算法在王道书籍P203),然后进行排序,算法复杂度为O(V+E)+O(所有路径之和进行排序)

int GetMinTurnPath(Start,Dest,Buff,len)
{
    if(Start==NULL)
        return

    //递归结束条件
    if(Start==Dest)
        return 0;

    //直走直到遇到有转弯,转弯可能一个向前,一个转弯
    Move forward until across with turn

    //
    Path1 = 1 + GetMinTurnPath(ForWard,Dest)
    Path2 = GetMinTurnPath(Turn,Dest);

    return max(Path1,Path2)
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 因为之前就复习完数据结构了,所以为了保持记忆,整理了一份复习纲要,复习的时候可以看着纲要想具体内容。 树 树的基本...
    牛富贵儿阅读 12,050评论 3 10
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,354评论 0 33
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,141评论 18 399
  • 1 序 2016年6月25日夜,帝都,天下着大雨,拖着行李箱和同学在校门口照了最后一张合照,搬离寝室打车去了提前租...
    RichardJieChen阅读 10,619评论 0 12
  • 拟了这个标题,有一秒突然觉得神奇,觉得时光飞逝,一眨眼我竟然也成了谈婚姻的人了。与老公虽然相识5年,但步入...
    断舍离的世界阅读 4,039评论 5 6