码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • CF1294F 题解


    传送门(洛谷)

    在这里插入图片描述
    看到大佬们都是用的 O ( n ) O(n) O(n) 的做法,本蒟蒻不会,就按合情合理的思路写了一个 O ( n log ⁡ n ) O(n\log n) O(nlogn) 的做法。

    首先可以确定,其中的两个点肯定是直径的两个端点。感性理解一下,如果不是的话,那么把其中的点换成直径的一个端点,答案一定不会更差,因为直径已经是树上的最长路径了。然后问题就变成了在树上找到一个点,使它到直径的两个端点的路径和直径的并所经过的边数最多。我们考虑一个简单的不能算容斥的容斥。

    在这里插入图片描述
    拿这棵树来说,假如直径的两个端点是 1 1 1 和 6 6 6,我们要找 5 5 5 这个点,那么分别记录下来直径的两个端点到其余点的距离,然后我们将其中的一个端点设为根,把其余点的深度和求 l c a lca lca 用的数组预处理出来。那么我们可以求出 5 5 5 和深度较深的那个端点的 l c a lca lca,然后就是一个小的容斥,假设两个端点到 5 5 5 的距离分别为 d i s 1 dis1 dis1 和 d i s 2 dis2 dis2,那么答案就是 d i s 1 + d i s 2 + d e p [ 5 ] − d e p [ l c a ] dis1+dis2+dep[5]-dep[lca] dis1+dis2+d

  • 相关阅读:
    Java获取当前时区时间LocalDateTime与System.currentTimeMillis
    浅析vue3PDF插件不显示文字
    一类综合的模糊化自适应滑模控制
    JDBC-02:操作访问数据库时使用Statement操作数据表的弊端
    search——single list
    ARMv7-A 那些事 - 5.CP15协处理器
    在线客服系统源码开发实战总结:需求分析及前端代码基本技术方案
    halcon 矩形相似度 rectangularity
    若依(ruoyi)管理系统(前后端分离版)本地运行教程(Windows)
    做外贸必知——你还不知道外贸拼箱技巧吗
  • 原文地址:https://blog.csdn.net/glorious_dream/article/details/127655880
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号