题干:

题目大意:

有一块草坪,长为l,宽为w,在它的水平中心线上有n个位置可以安装喷水装置,各个位置上的喷水装置的覆盖范围为以它们自己的半径ri为圆。求出最少需要的喷水装置个数,如果无论如何都不能覆盖,就输出-1。

解题报告:

这题就是个区间覆盖问题的变形,,虽然给的是一个个的圆,但是我们不难发现求出与上下边的交点,这一部分区域才是我们的有效区域,然后求个区间覆盖就行了、、、nlogn的算法按说不应该TLE啊,,,但是该优化的都优化了还是TLE,看了题解发现有个剪枝,,(但是说实话这个题卡时间没必要吧、、TLE变0ms)

emmm今天又想了一下好像不是TLE的问题,,这样会WA吧、、因为本来可能覆盖不到的地方你都变成覆盖得到了、、你求边界那里就不对、、对一个负数去开平方根???可能这样会认为是TLE吧、、

AC代码:

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<queue>
#include<map>
#include<vector>
#include<set>
#include<string>
#include<cmath>
#include<cstring>
#define ll long long
#define pb push_back
#define pm make_pair
#define fi first
#define se second
using namespace std;
const int MAX = 2e5 + 5;
struct Node {double st,ed;Node(){}Node(double st,double ed):st(st),ed(ed){}bool operator<(const Node & b) const{if(st != b.st) return st < b.st;return ed > b.ed;}
} node[MAX];
int tot,cnt;
int main()
{int n;double l,w,x,r;while(~scanf("%d%lf%lf",&n,&l,&w)) {tot=cnt=0;for(int i = 1; i<=n; i++) {scanf("%lf %lf",&x,&r);if(r < w/2) continue;//cin>>x>>r;//cout << x<< r << endl;node[++tot] = Node(x-sqrt(r*r-w*w/4),x+sqrt(r*r-w*w/4));//cout << x-sqrt(r*r-w*w/4) << endl;}sort(node+1,node+tot+1);//for(int i = 1; i<=tot; i++) printf("%f  %f\n",node[i].st,node[i].ed);double cure,curs;curs=cure=0;int flag = 0;for(int i = 1; i<=tot; ) {if(node[i].st > curs) {break;   }while(i<=tot && node[i].st<=curs) {if(node[i].ed > cure) {cure = node[i].ed;}i++;}cnt++;curs = cure;if(curs >= l) {flag=1;break;}}if(flag == 0) puts("-1");else printf("%d\n",cnt);}return 0 ;} 

还有一个没有排序的算法、这样写就不需要加剪枝了。,。但是不知道为什么这样可以。

*【UVA - 10382】Watering Grass(贪心,区间覆盖问题,思维)相关推荐

  1. UVa 10382 - Watering Grass

    链接: http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=113&pa ...

  2. 10382 - Watering Grass(贪心 区间覆盖问题)洒水面覆盖

    double qiuzhi(int id) {double t1=cc[id].rid*cc[id].rid;double t2=w*w/4;double t3=t1-t2;double t4=sqr ...

  3. 高效算法——E - 贪心-- 区间覆盖

    E - 贪心-- 区间覆盖 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=85904#problem/E 解题思路: 贪心思想, ...

  4. 贪心 区间覆盖最小值

    贪心 区间覆盖最小值 POJ 2376 大概题意: 从1到T区间内,必须保证每个点都有牛在工作,给出每头牛的工作时间,求需用到的最小的牛的数量,无解输出-1 一开始以为组合[1,4] [5,T]不算覆 ...

  5. UVa10382 - Watering Grass(贪心算法)

    问题:给出一个长为l,宽为w的绿化带,n个喷水装置及其对就位置x和影响半径r.问最少需要多少个喷水装置能全覆盖此绿化带 思路:首先要计算喷水装置可以覆盖的区间,如果喷水装置的影响半径小于等于w/2,是 ...

  6. 贪心---区间覆盖问题(水题)

    区间覆盖问题 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 设x1 , x2 ,-- , xn 是实直线上的n 个点. ...

  7. UVA10382 - Watering Grass 题解

    原题链接 Online Judge: 10382 - Watering Grass Virtual Judge: Watering Grass - UVA 10382 洛谷:UVA10382 Wate ...

  8. Watering Grass UVA - 10382 贪心

    问题 https://vjudge.net/problem/UVA-10382 分析 将一个点的覆盖范围看作是一个长方形,舍弃弓形区域,变成区间覆盖问题,用贪心法 注意:bb-ww/4有可能小于0,要 ...

  9. 区间覆盖全部类型及部分精选习题汇总详解(贪心策略)

    内容如下: 1)区间完全覆盖问题 问题描述:给定一个长度为m的区间,再给出n条线段的起点和终点(注意这里是闭区间),求最少使用多少条线段可以将整个区间完全覆盖 样例: 区间长度8,可选的覆盖线段[2, ...

最新文章

  1. SRWebSocket源码浅析(上)
  2. “LM/w3svc/1/root /***” 别名已存在
  3. 问:一行Python代码到底能干多少事情?(三)
  4. 【牛客 - 289H】约会(思维,数学,奇偶数,水题)
  5. 主机数,子网数,网络号,主机号
  6. 字符串转整数,不使用任何C语言库函数
  7. Android SQLite数据库
  8. LeetCode_9_回文数字
  9. 构建一个基于UIView的类别
  10. 爬虫之模拟登录、自动获取cookie值、验证码识别
  11. python爬取别人qq空间相册_Python网络爬虫5 - 爬取QQ空间相册
  12. 程序带来这些新的机会,创业新浪潮才刚开始!
  13. django按日期查询数据
  14. cocos2dx2.2添加音乐音效以及设置音量
  15. 设计模式之禅【中介者模式】
  16. 直流斩波电路在matlab中的建模与仿真,基于MATLAB/Simulink的直流斩波电路分析
  17. Codeforces-1610 C: Keshi Is Throwing a Party
  18. 从P1到P7——我在淘宝这7年
  19. 基于web的科研项目管理系统设计与实现
  20. 榆熙电商:商家如何做好店铺运营?

热门文章

  1. 第七课 循环神经网络与自然语言处理
  2. [Leedcode][JAVA][第1162题][BFS]
  3. AtCoder - 4172 Modulo Summation 贪心
  4. 和县机电工程学校工业机器人_【校企合作】学校举行工业机器人教学系统捐赠仪式...
  5. A. Arithmetic Array Codeforces Round #726 (Div. 2)
  6. 计算机中函数counta表示,excel中counta函数的使用方法
  7. ESlint静态代码检测工具安装
  8. 字节跳动专家会_字节跳动招聘直播策略运营专家/经理/海外财务AR BP,ACCA优先...
  9. 深入浅出FSUIPC的作用以及使用方法
  10. WINCE 加入驱动DLL步骤