zoukankan      html  css  js  c++  java
  • Codeforces Round #514 (Div. 2)

    D. Nature Reserve

    题目描述:给定(n)个点,找出一个圆,使得这个圆与(y)轴相切并且包含所有的点,问最小半径。

    solution
    解法倒是挺套路的。二分答案,求出每个点对应的圆心可行域,判断有没有交集。问题是答案可能会很大,要用long double,而我二分又习惯了用eps来判断退出,但因为精度的问题,这个条件基本不会退出,所以以后碰到二分小数的,还是直接枚举二分次数比较好。

    时间复杂度:(O(能过))

    E. Split the Tree

    题目描述:有一棵树,每个点有一个权值,现在要用(m)条路径来覆盖这棵树,每条路径后一个点要是前一个点的父亲,路径上所有点的权值和不能超过(S),点数不能超过(L),路径不能有相交部分,问(m)的最小值。

    solution
    首先,路径不能有相交部分这个条件是没有用的,因为就算有相交的部分,也可以通过调整使得不相交。暴力维护每个点的子树的叶子延伸到这个点的每条路径的点数和总和,不符合条件的不延伸,如果没有路径延伸到这个点,那说明这个点要作为路径开头,答案加一。这竟然能过。

    其实可以先倍增预处理出每个点最远可以向上走多远,然后对于每个点,只有一条路径可以穿过这个点继续往上走,那显然要选一条往上走能走最远的那条路径,其它路径不延伸,如果没有一条路径能穿过这个点,那答案就要加一,这个点作为开头往上走。

    时间复杂度:(O(nlogn))

  • 相关阅读:
    C#趣味程序---车牌号推断
    使用 C# 开发智能手机软件:推箱子(十四)
    【Oracle错误集锦】:ORA-12154: TNS: 无法解析指定的连接标识符
    java中你确定用对单例了吗?
    linux tty设置详解
    tty linux 打开和设置范例
    C和C++之间库的互相调用
    Android 编译参数 LOCAL_MODULE_TAGS
    pthread_once 和 pthread_key
    Android系统root破解原理分析
  • 原文地址:https://www.cnblogs.com/GerynOhenz/p/9746805.html
Copyright © 2011-2022 走看看