貌似是当年楼教主出的题目。
有N个旅店,两个属性,距离D,价格C。选择旅店,若选择M
1.比M近的,价格比它高
2.比M便宜的,距离比它远
求有多少个这样的旅店
① 暴力做法
两次排序,按照不同的关键字。然后扫描,过程中记录下前面另一个关键字的最小值,然后比较。若数组中sel为2则是。
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define mem(a) memset(a,0,sizeof(a))
#define inf 0x3f3f3f3f
#define maxn 100+10000
struct P{
int a,b,c;
}p[maxn];
int sel[maxn];
bool cmp1(const struct P &a,const struct P &b)
{
return a.a<b.a;
}
bool cmp2(const struct P &a,const struct P &b)
{
return a.b<b.b;
}
int main()
{
int n;
while(~scanf("%d",&n) && n)
{
for(int i=0;i<n;i++)
scanf("%d%d",&p[i].a,&p[i].b),p[i].c=i;
sort(p,p+n,cmp1);
mem(sel);
int D=p[0].b;sel[p[0].c]++;
for(int i=1;i<n;i++)
if(p[i].b<D)
sel[p[i].c]++,D=p[i].b;
sort(p,p+n,cmp2);
D=p[0].a;sel[p[0].c]++;
for(int i=1;i<n;i++)
if(p[i].a<D)
sel[p[i].c]++,D=p[i].a;
int ans=0;
for(int i=0;i<n;i++)
if(sel[i]==2)
ans++;
cout<<ans<<endl;
}
}
②条件转化
看了discuss中,
1。当任意两个旅馆的距离不等时,那么任意比m距离近的旅馆都比m的价格贵的m一定是candidate hotel 的。
2。当存在两个旅馆的距离相等时,那么价格贵得那个一定不是candidate hotel 的。
这个其实可以倒过来看,正者是满足第一个条件,反过来倒着看比我便宜的必然在后面,那么也就比我远
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define mem(a) memset(a,0,sizeof(a))
#define inf 0x3f3f3f3f
#define maxn 100+10000
struct P{
int a,b,c;
}p[maxn];
bool cmp1(const struct P &a,const struct P &b)
{
if(a.a==b.a)
return a.b<b.b;
return a.a<b.a;
}
int main()
{
int n;
while(~scanf("%d",&n) && n)
{
for(int i=0;i<n;i++)
scanf("%d%d",&p[i].a,&p[i].b),p[i].c=i;
sort(p,p+n,cmp1);
int D=p[0].b;
int ans=1;
for(int i=1;i<n;i++)
{
if(p[i].a==p[i-1].a)
continue;
if(p[i].b<D)
ans++,D=p[i].b;
}
cout<<ans<<endl;
}
}