美团2021校招笔试-编程题题解

题目链接

小美的送花线路

在这里插入图片描述

题意:
有n个点的一棵树,玩家开始在1号点,要遍历所有的点,使得走过的路程最短。
问:每个点到1号点的 距离和 是多少? 玩家遍历的最短路程是多少?

  • 题解
  1. 由于玩家行走的路径是有来有回,因此需要简化问题,将行走分为两部分,以c号点为界。可以得到一个结论:去往其他三个方向后都得回来,只有某一个方向是可以一去不返
  2. 那么我们可以操控的空间就是:令一去不返这个方向距离 1号点最远。也就是找出距离1号点最远的点u,转化为树上的遍历问题。
    在这里插入图片描述
  • 穿插知识点:树的直径

定义:一棵树的直径就是这棵树上存在的最长路径(也就是距离最远的两个点相连的路径)。

  • 找出直径:
    • 0
      点赞
    • 2
      收藏
      觉得还不错? 一键收藏
    • 0
      评论
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值