zoukankan      html  css  js  c++  java
  • 【贪心】Highway

    [UVa1615]Highway

    算法竞赛入门经典第8章8-11(P255)

    题目大意:给定平面上N个点和D,要求在x轴上选出一些点,每个给定的点至少与一个选出的点欧几里得距离<=D

    试题分析:对于每个点,我们只需要以其为圆心做半径为D的圆,求其与x轴的两个交点,确定这个点的一条线段,然后进行线段覆盖形贪心即可。

    代码:

     

    #include<iostream>
    #include<cstring>
    #include<cstdio>
    #include<cmath>
    #include<algorithm>
    #define LL long long
    using namespace std;
    
    inline int read(){
    	int x=0,f=1;char c=getchar();
    	for(;!isdigit(c);c=getchar()) if(c=='-') f=-1;
    	for(;isdigit(c);c=getchar()) x=x*10+c-'0';
    	return x*f;
    }
    const int INF = 999999;
    const int MAXN = 100001;
    int L,D; int N;
    struct data{
    	int x,y;
    	double lx,ly;
    }a[MAXN+1];
    
    bool cmp(data a,data b){
    	return a.ly<b.ly;
    }
    
    int main(){
    	while(scanf("%d%d",&L,&D)!=EOF){
    		N=read();
    		for(int i=1;i<=N;i++){
    			a[i].x=read(),a[i].y=read();
    		     a[i].lx=(double)a[i].x-sqrt((double)D*(double)D-(double)a[i].y*(double)a[i].y);
                 a[i].ly=(double)a[i].x+sqrt((double)D*(double)D-(double)a[i].y*(double)a[i].y);
                 a[i].lx=max(a[i].lx,0.0);
                 a[i].ly=min(a[i].ly,(double)L);
    		}
    		sort(a+1,a+N+1,cmp);
    		int tmp=-1,ans=0;
    		for(int i=1;i<=N;i++){
    			if(tmp<a[i].lx){
    				tmp=a[i].ly; ans++;
    			}
    		}
    		printf("%d
    ",ans);
    	}
    }

     

  • 相关阅读:
    c语言学习笔记(6)——for和while循环
    c语言学习笔记(5)——进制
    c语言学习笔记(4)——流程控制
    ckeditor复制粘贴word
    java上传超大文件
    plupload上传整个文件夹
    vue+上传文件夹
    php+上传大文件
    web+文件夹上传
    2G以上的大文件如何上传
  • 原文地址:https://www.cnblogs.com/wxjor/p/7544099.html
Copyright © 2011-2022 走看看