首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

3027 线段覆盖 2

3027 线段覆盖 2  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解  查看运行结果 题目描述 Description 数轴上有n条线段线段的两端都是整数坐标...,坐标范围在0~1000000,每条线段有一个价值,请从n条线段中挑出若干条线段,使得这些线段两两不覆盖(端点可以重合)且线段价值之和最大。...n<=1000 输入描述 Input Description 第一行一个整数n,表示有多少条线段。...接下来n行每行三个整数, ai bi ci,分别代表第i条线段的左端点ai,右端点bi(保证左端点<右端点)和价值ci。...Data Size & Hint 数据范围 对于40%的数据,n≤10; 对于100%的数据,n≤1000; 0<=ai,bi<=1000000 0<=ci<=1000000 思路:首先我们按照正常线段覆盖问题的方法把所有线段按照结束顺序排序

82360
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    棋盘覆盖问题Java

    棋盘覆盖问题Java) 1、问题描述 2、算法设计思路 3、代码实现 4、复杂度分析 5、参考 ---- ---- 1、问题描述 在一个2k×2k个方格组成的棋盘中,若恰有一个方格与其他方格不同,...在棋盘覆盖问题中,要用下图所示的4种不同形态的L型骨牌覆盖一个给定的特殊棋盘上除特殊方格以外的所有方格,且任何2个L型骨牌不得重叠覆盖。...易知,在任何一个2k×2k的棋盘覆盖中,用到的L型骨牌个数恰好为(4k - 1)/3。 2、算法设计思路 使用分治策略,可以设计出解棋盘覆盖问题的简洁算法。...为了将这3个无特殊方格的子棋盘转化为特殊棋盘,可以用一个L型骨牌覆盖这3个较小棋盘的会合处,如下图(b)所示,从而将原问题转化为4个较小规模的棋盘覆盖问题。...由于覆盖2k×2k棋盘所需的L型骨牌个数为(4k - 1)/3,所以此算法是一个在渐进意义下的最优算法。 5、参考 算法分析与设计(第四版)

    76520

    1214 线段覆盖 非结构体做法

    1214 线段覆盖  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解 题目描述 Description     给定x轴上的N(0<N<100)条线段,每个线段由它的二个端点...有些线段之间会相互交叠或覆盖。请你编写一个程序,从给出的线段中去掉尽量少的线段,使得剩下的线段两两之间没有内部公共点。...所谓的内部公共点是指一个点同时属于两条线段且至少在其中一条线段的内部(即除去端点的部分)。 输入描述 Input Description     输入第一行是一个整数N。...接下来有N行,每行有二个空格隔开的整数,表示一条线段的二个端点的坐标。 输出描述 Output Description     输出第一行是一个整数表示最多剩下的线段数。...样例输入 Sample Input 3 6  3 1  3 2  5 样例输出 Sample Output 2 贪心解法:首先将线段端点调整为左端点小于(或等于)右端点;第二,根据右端点将线段从小到大排序

    47870

    java 实现棋盘覆盖问题

    问题描述:在一个2k*2k的棋盘中,有一个特殊方格,要求用L型骨牌覆盖满除特殊方格外的所有其他方格,且骨牌不得重叠....解题思想: 采用分治法解决该问题。分治法是把一个规模很大的问题分解为多个规模较小、类似的子问题,然后递归地解决所有子问题,最后再由子问题的解决得到原问题的解决。...右上的子棋盘若不存在特殊方格,将该子棋盘左下角的那个方格覆盖为特殊方格 左下的子棋盘若不存在特殊方格,将该子棋盘右上角的那个方格覆盖为特殊方格 右下的子棋盘若不存在特殊方格,将该子棋盘左上角的那个方格覆盖为特殊方格...;  /** 模拟棋盘  */  static int[][] board;  /** 模拟骨牌(相同数字为同一块骨牌)  */  static int tile = 1;  /**   * 棋盘覆盖问题...由于覆盖2k*2k的棋盘所需的骨牌个数为(4k-1)/3,所以此算法是一个渐进意义下最优算法。

    1.8K110

    棋盘覆盖问题

    Tags: 算法 棋盘覆盖问题 ---- 【问题描述】 在一个2^k×2^k个方格组成的棋盘中,若有一个方格与其他方格不同,则称该方格为一特殊方格,且称该棋盘为一个特殊棋盘.显然特殊方格在棋盘上出现的位置有...k = 3,棋盘大小8 x 8 在棋盘覆盖问题中,要用下图中 4 中不同形态的** L 型骨牌覆盖一个给定的特殊棋牌上除特殊方格以外的所有方格,且任何 2 个 L 型骨牌不得重叠覆盖**。...为了将这 3 个无特殊方格的子棋盘转化为特殊棋盘,我们可以用一个 L 型骨牌覆盖这 3 个较小的棋盘的汇合处,如下图所示,这 3 个子棋盘上被 L 型骨牌覆盖的方格就成为该棋盘上的特殊方格,从而将原问题化为...4 个较小规模的棋盘覆盖问题。...【算法实现】 下面讨论棋盘覆盖问题中数据结构的设计: (1)棋盘:可以用一个二维数组board[size][size]表示一个棋盘,其中,size=2^k。

    3.2K100

    LintCode 线段树系列问题线段树的构造,线段树的构造||,线段树的查询,线段树的查询II,线段树的修改)线段树的构造线段树的构造 II线段树的查询线段树查询 II线段树的修改

    线段树(又称区间树), 是一种高级数据结构,他可以支持这样的一些操作: 查找给定的点包含在了哪些区间内 查找给定的区间包含了哪些点 线段树的构造 题目 线段树是一棵二叉树,他的每个节点包含了两个额外的属性...实现一个 build 方法,接受 start 和 end 作为参数, 然后构造一个代表区间 [start, end] 的线段树,返回这棵线段树的根。...样例 对于数组 [0, 空,2, 3], 对应的线段树为: ?...该方法将 root 为跟的线段树中 [start, end] = [index, index] 的节点修改为了新的 value ,并确保在修改后,线段树的每个节点的 max 属性仍然具有正确的值。...样例 对于线段树: ?

    51630

    java — 重载和覆盖

    (override):当父类中的某些方法不能满足需要的时候,子类改写父类的方法,当父类中的方法被覆盖之后,除非使用super关键字,否则无法再调用父类的方法。...覆盖的条件:   1、“三同一不低”:方法名称、参数列表、返回类型相同,子类的访问修饰符的权限不能比父类低;   2、子类方法不能比父类抛出更多的异常。...即子类所抛出的异常必须和父类方法所抛出的异常一致,或子类中不抛出异常;   3、被覆盖的方法不能是final类型的,因为final类型的方法无法被子类覆盖;   4、被覆盖的方法不能是private类型的...,否则在子类中只是定义类一个新的方法,并没有对其进行覆盖; 5、被覆盖的方法不能是static类型的,如果父类的方法为static类型的,而子类的方法不是static类型的,那么两个方法除了这一点外其他都满足覆盖条件...反之亦然,即使父类和子类中的方法都是static类型的,并且满足覆盖条件,但是仍然不会发生覆盖,因为static是在编译的时候将静态方法和类的引用类型进行匹配。

    86670

    RMQ问题(线段树算法,ST算法优化)

    RMQ (Range Minimum/Maximum Query)问题是指: 对于长度为n的数列A,回答若干询问RMQ(A,i,j)(i,j<=n),返回数列A中下标在[i,j]里的最小(大)值,也就是说...,RMQ问题是指求区间最值的问题 主要方法及复杂度(处理复杂度和查询复杂度)如下: 1.朴素(即搜索) O(n)-O(n) 2.线段树(segment tree) O(n)-O(qlogn)...3.ST(实质是动态规划) O(nlogn)-O(1) 线段树方法: 线段树能在对数时间内在数组区间上进行更新与查询。...可知 N  个元素的线段树的高度 为 [logN] + 1(只有根节点的树高度为0) . 下面是区间 [0, 9]  的一个线段树: ?...使用线段树解决RMQ问题,关键维护一个数组M[num],num=2^(线段树高度+1). M[i]:维护着被分配给该节点(编号:i 线段树根节点编号:1)的区间的最小值元素的下标。

    1.1K60

    计算几何之线段相交问题(平面扫描)

    给出n条平行于x轴或y轴的线段,输出其交点数 求n条线段的交点,可以用抽选配对的方式来遍历所有的情况,这样子时间复杂度为O(n2)....与轴平行的线段相交问题(曼哈顿几何)可以通过平面扫描(sweep)高效求解。平面扫描算法的思路是将一条与x轴(y轴)平行的直线向上(向右)平行移动,在移动过程中寻找交点,这条直线被称为扫描线。...扫描线在每次遇到平面上线段的端点的时候停止移动,并且检查该位置上的线段交点。 为了进行上述的处理,我们需要先将输入的线段的端点按照y的大小进行排序,然后让扫描线向y轴正向移动。...在扫描线移动的过程中,算法会将扫描线穿过的垂直线段(与y轴平行)临时记录下来,等到扫描线与水平线段重叠的时候,检查水平线段的范围内是否存在垂直线段上的点,然后将这些点作为交点输出。...右端点、上端点的顺序排列 else return p.y < ep.p.y; } }; EndPoint EP[2 * MAXN]; //端点列表 //线段相交问题

    97830

    php 覆盖率_java代码覆盖率工具

    简介:最近研究了PHP代码覆盖率的测试,后面发现了github一个开源项目(https://github.com/sebastianbergmann/php-code-coverage) ,对PHP代码覆盖率测试已经做得很好了...php代码 1、在所需要测试的php文件里加一行代码,来引入prepend.php,如下: include_once("/******/prepend.php"); 如 测试echoNumber.php的覆盖率...二、查看报告 1、用浏览器打开报告文件夹下的index.html,如下图: 因为我src下有三个php文件,所以这里展示了3行 2、点开一个文件名,查看具体的覆盖情况,运行的代码绿色显示,如下图:...3、通过这个报告,我们能看到行的覆盖率、函数的覆盖率和类的覆盖率。...最后:我们真实测试覆盖率时不可能去每一个php文件里添加一行代码,可以考虑在真实项目的index文件里添加 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

    1.1K40

    贪心算法(集合覆盖问题)

    首先来看一个集合覆盖问题: 假如存在下面需要付费的广播台,以及广播台信号可以覆盖的地区,如何选择最少的广播台,让所有地区都可以接收到信号?...这个问题就是经典的用贪心算法求解的问题。贪心算法是指在每一步选择中都采取最优的策略,从而希望能够导致结果是最优的一种算法。贪心算法所得到的结果并不一定是最优的解,但都是相对接近最优解的结果。...二、案例: 要解决上面的问题,该怎么做呢?常规的做法如下: 列出k1、k2、k3、k4、k5的所有可能组合,总共就有2^5 = 32中组合。怎么来的?就是5个数不考虑顺序进行排列组合嘛。...按照遍历顺序,选择k2; 再把k2覆盖的地区从保存地区的集合中去掉,那么现在就剩下成都、杭州、大连三个地方未覆盖了; 遍历广播台集合,发现k3和k5都可以覆盖两个,按照遍历顺序,选择k3; 再把k3覆盖的地区从保存地区的集合中去掉...三、代码实现: 将上面的问题用代码实现出来。

    1.2K20
    领券