「个人训练」Radar Installation(POJ-1328)
这条题目A了十次。。。emmmmm 其实不难就是一个贪心。。。。
先说下算法(之前的和现在的)
之前考虑的其实很简单。用平面几何即可将雷达可以放置的区域转化为区间(顺便判断是否无解。问题就比较简单了:先排序。然后我们第一个区间我们肯定是放在区间的最右边,然后对后面的我们如何处理呢?若后一个区间的左边在目前区间的右边,我们肯定是不用动这个雷达的摆放位置的;如果不满足,那么我们就要看看后一个区间的右边和这个区间的摆放位置了。如果后一个区间的右边在目前区间的右边的左边,那么我们就应当放在后一个区间的右边。按照这个思路就可以了。
再谈下自己错误的地方
- 浮点数,我前面几次全部都是用int保存的,省略了很多精度,导致了错误还死活调不出来。(这个应该是主要错误。)
- 这题有大量i/o,应当采用c-style的输入输出或者关掉tie。
- 各种代码细节问题,这个是编程基本功,以后慢慢提升吧。
代码
原题的代码套用了一个网上的模板,看起来有点恐怖233
#include <cctype>
#include <numeric>
#include <climits>
#include <cmath>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <string>
#include <sstream>
#include <algorithm>
#include <complex>
#include <deque>
#include <list>
#include <map>
#include <queue>
#include <set>
#include <stack>
#include <vector>
#include <utility>
#include <bitset>
using namespace std;
#define REP(i,n) for(int i=0;i!=static_cast<int>(n);++i)
#define REP_1(i,n) for(int i=1;i<=static_cast<int>(n);++i)
#define FOR(i,a,b) for(int i=static_cast<int>(a);i<static_cast<int>(b);++i)
#define FOR_1(i,a,b) for(int i=static_cast<int>(a);i<=static_cast<int>(b);++i)
#define DWN(i,b,a) for(int i=static_cast<int>(b);i>static_cast<int>(a);--i)
#define DWN_1(i,b,a) for(int i=static_cast<int>(b);i>=static_cast<int>(a);--i)
#define ECH(it,A) for(auto it=A.begin();it!=A.end();++it)
#define REP_2(i,j,n,m) REP(i,n) REP(j,m)
#define REP_2_1(i,j,n,m) REP_1(i,n) REP_1(j,m)
#define REP_3(i,j,k,n,m,l) REP(i,n) REP(j,m) REP(k,l)
#define REP_3_1(i,j,k,n,m,l) REP_1(i,n) REP_1(j,m) REP_1(k,l)
#define ALL(A) A.begin(), A.end()
#define LLA(A) A.rbegin(), A.rend()
#define CPY(A,B) memcpy(A,B,sizeof(A))
#define INS(A,P,B) A.insert(A.begin()+P,B)
#define ERS(A,P) A.erase(A.begin()+P)
#define BSC(A,X) find(ALL(A),X)// != A.end()
#define CTN(T,X) (T.find(X)!=T.end())
#define SZ(A) static_cast<int>(A.size())
#define PB push_back
#define MP(A,B) make_pair(A,B)
#define P(T) pair<T,T>
#define fi first
#define se second
#define D(v) (cout<< #v <<" is equal to "<<v<<endl)
#define DP(v) (cout<< #v << " is equal to "<<v.fi<<" "<<v.se<<endl)
#define ZERO(v) memset(v,0,sizeof(v))
#define MIO(v) memset(v,-1,sizeof(v))
#define IOS std::ios::sync_with_stdio(false); std::cin.tie(nullptr); std::cout.tie(nullptr);
const int inf=0x3f3f3f3f;
//const int MAXN;
const double eps=1e-6;
const double pi=acos(-1.0);
typedef long long ll;
typedef unsigned long long ull;
typedef long double ld;
inline int sgn(double x)
{
return (x>eps)-(x<-eps);
}
int d;
struct Interval
{
double l,r;
Interval(double _l=0,double _r=0):l(_l),r(_r) {}
Interval(P(double) p):l(p.fi-sqrt(d*d-p.se*p.se)),r(p.fi+sqrt(d*d-p.se*p.se)) {}
bool operator < (const Interval& rhs) const
{
if (r==rhs.r) return l<rhs.l;
else return r<rhs.r;
}
};
int main()
{
int n;
int kase=0;
while(scanf("%d%d",&n,&d)==2)
{
if(!n&&!d) break;
int ans=1;
bool isVaild=true;
if(d<0)//d能小于0
isVaild=false;
vector<Interval> vec;
REP(i,n)
{
double x,y; scanf("%lf%lf",&x,&y);
if(double(d)<fabs(y)) { isVaild=false;ans=-1; }
else vec.PB(MP(x,y));
//cout<<vec[i].l<<" "<<vec[i].r<<endl;
}
if(ans!=-1)
{
sort(ALL(vec));
int tmp=0;
int len=vec.size();
for(int i=1;i!=len;++i)
{
if(vec[i].l>vec[tmp].r)
{
ans++;
tmp=i;
}
else if(vec[i].r<vec[tmp].r)
tmp=i;
}
}
printf("Case %d: %d\n",++kase,ans);
}
return 0;
}
「个人训练」Radar Installation(POJ-1328)的更多相关文章
- Radar Installation POJ - 1328
Assume the coasting is an infinite straight line. Land is in one side of coasting, sea in the other. ...
- Radar Installation POJ - 1328(贪心)
Assume the coasting is an infinite straight line. Land is in one side of coasting, sea in the other. ...
- Greedy:Radar Installation(POJ 1328)
装雷达 题目大意,就是令在海岸线的(直线)一边是海(y>0),另一边是陆地(y<=0),在海岸线上装雷达,雷达可以覆盖的范围为d,海上有岛,(x,y),问你应该怎么装雷达,才能做到技能雷达 ...
- Radar Installation POJ - 1328 (贪心)
题目大意(vj上的翻译版本) 假定海岸线是无限长的直线.陆地位于海岸线的一侧,海洋位于另一侧.每个小岛是位于海洋中的一个点.对于任何一个雷达的安装 (均位于海岸线上),只能覆盖 d 距离,因此海洋中的 ...
- 【贪心】「poj1328」Radar Installation
建模:二维转一维:贪心 Description Assume the coasting is an infinite straight line. Land is in one side of coa ...
- 「日常训练」 Fire!(UVA-11624)
与其说是训练不如说是重温.重新写了Java版本的代码. import java.util.*; import java.math.*; import java.io.BufferedInputStre ...
- 「国庆训练」ArcSoft's Office Rearrangement(HDU-5933)
题目与分析 题解见https://blog.csdn.net/cmershen/article/details/53200922. 训练赛场上我们写出来了--在4小时50分钟的时候...激情补题啊.. ...
- 「国庆训练」Bomb(HDU-5934)
题意 给定\(n\)个炸弹,每个炸弹的坐标与代价与影响范围给定,炸弹会引爆影响范围内其他所有炸弹.求引爆所有炸弹的最小代价. 分析 先做\(n^2\)的循环,然后建图,对\(i\)能引爆\(j\)建边 ...
- 「日常训练」ZgukistringZ(Codeforces Round #307 Div. 2 B)
题意与分析(CodeForces 551B) 这他妈哪里是日常训练,这是日常弟中弟. 题意是这样的,给出一个字符串A,再给出两个字符串B,C,求A中任意量字符交换后(不限制次数)能够得到的使B,C作为 ...
随机推荐
- jmeter报"msg":"Content type 'application/x-www-form-urlencoded;charset=UTF-8' not supported"的解决方法
1.报"msg":"Content type 'application/x-www-form-urlencoded;charset=UTF-8' not supporte ...
- activeMQ消息队列的使用
ActiveMQ解决问题: 1.解决服务之间的耦合 2.增加系统并发处理量. 它使用的是标准生产者和消费者模型.有两种数据结构:Queue/Topic 1.Queue队列,生产者生产一个消息,只能由 ...
- 课时60.CSS的固定格式(掌握)
CSS就是用来设置样式的,美化界面的 如何验证? 打开一个京东首页 删除掉css样式 发现页面变得非常难看 由此我们验证了一个说法,css就是用来美化界面的 1.格式: <style type= ...
- Question 20171116 StringBuffer和StringBuilder的扩容机制
StringBuffer和StringBuilder都是继承自AbstractStringBuilder,它们两个的区别在于buffer是线程安全的,builder是线程不安全的,前者安全效率低,后者 ...
- Android手机上抓包神器
Packet Capture 一款依托安卓系统自身VPN来达到免Root抓取数据包的应用程序.Packet Capture一个使用SSL网络解密的 捕获数据包/网络嗅探 工具,虽然它的功能并不丰富,但 ...
- Shiro 登录认证源码详解
Shiro 登录认证源码详解 Apache Shiro 是一个强大且灵活的 Java 开源安全框架,拥有登录认证.授权管理.企业级会话管理和加密等功能,相比 Spring Security 来说要更加 ...
- ios appstore 上架应用被拒绝原因
ios appstore 上架应用被拒绝原因 应用程序崩溃 界面布局有明显错误挂羊头卖狗头的应用包括未公开的或隐藏功能的使用私有API应用程序读取或写入数据超出其指定的容器区域以任何方式下载代码的应用 ...
- zepto 基础知识(4)
61.prev prev() 类型:collection prev(selector) 类型:collection 获取对相集合中每一个元素的钱一个兄弟节点,通过选择器来进行过滤 62.prev pr ...
- VULTR的VPS在centos的操作系统中出现网站无法访问 80端口被firewall禁止
导语:叶子在为一位客户配置web服务器环境的时候,出现网站不能访问的情况,但ping正常.客户的服务器是在VULTR上购买的VPS,安装的操作系统为centos 7.3.经过叶子的分析,认为是防火墙阻 ...
- jquery点击li 获取当前父节点所在类的索引
jquery点击li 获取当前父节点所在类的索引 $('.jbcz').find('.content li').click(function(){ //alert($('.jbcz').find('. ...