一道比较NB的套路题。

Description

  NBA每年都有球员选秀环节。通常用速度和身高两项数据来衡量一个篮球运动员的基本素质。假如一支球队里速度最慢的球员速度为minV,身高最矮的球员高度为minH,那么这支球队的所有队员都应该满足: A * ( height – minH ) + B * ( speed – minV ) <= C 其中A和B,C为给定的经验值。这个式子很容易理解,如果一个球队的球员速度和身高差距太大,会造成配合的不协调。 请问作为球队管理层的你,在N名选秀球员中,最多能有多少名符合条件的候选球员。

Input

  第一行四个数N、A、B、C 下接N行每行两个数描述一个球员的height和speed。

Output

  最多候选球员数目。

Sample Input

  4 1 2 10
  5 1
  3 2
  2 3
  2 1

Sample Output

  4

HINT

  1 <= N <= 5000,0<= height,speed <= 10000,A、B、C在长整型以内且为正数。

Solution

  最暴力的O(n^3)做法就是枚举minH和minV,加入满足条件的点即可。

  我们试着优化一下:

  一看到n=5000,肯定是n^2的做法,因此我们有枚举minH和minV其中一个的余地,所以还是枚举minV,把speed[i]<minV的点去除。

  然后我们把式子转化一下:

    

    

    

  由于我们枚举了minV,所以minV可以看做是一个常数,设C'=C+B*minV。

    

  这就很有意思,我们设X[i]=height[i],Y[i]=A*height[i]+B*speed[i]。于是每个运动员就对应平面直角坐标系中的点(X[i],Y[i])。

  当我们枚举minH的时候,就相当于在问有多少个点(X[i],Y[i])满足:

    ,这就是一个二维数点问题。

  把这些点按照X[i]排序从大到小加点,用(离散化加上)树状数组维护Y[i],就可以得到一个O(n^2logn)的做法。

  虽然时间复杂度爆炸但是小C才不会告诉你小C用这个做法过了该题。

  但是我们注意到随着minH的减小,A*minH+C'也是不断减小的,(A>0,虽然原题没说但是就算A为负数也是同理的做法)。

  所以我们把这些点不仅按X[i]排序,还要按Y[i]排序,用两个指针维护,按X[i]从大到小加点,并按Y[i]从大到小删点。

  再加上我们对这些点使用排序时用上插入排序,就可以得到一个O(n^2)的做法。

#include <cstdio>
#include <cstring>
#include <algorithm>
#define ll long long
#define MN 5003
using namespace std;
struct meg{int x,z; ll y;}a[MN];
int c1[MN],c2[MN];
bool u[MN];
int n,A,B,C,ans,tp1,tp2; inline int read()
{
int n=,f=; char c=getchar();
while (c<'' || c>'') {if(c=='-')f=-; c=getchar();}
while (c>='' && c<='') {n=n*+c-''; c=getchar();}
return n*f;
} void solve(ll CX)
{
register int i,j,k,sum=;
ll lt;
for (i=tp1,k=tp2;i;i=j)
{
lt=1LL*A*a[c1[i]].x+CX;
for (j=i;j&&a[c1[j]].x==a[c1[i]].x;--j)
if (a[c1[j]].y<=lt) ++sum,u[c1[j]]=true;
for (;k&&a[c2[k]].y>lt;--k)
if (u[c2[k]]) --sum,u[c2[k]]=false;
ans=max(ans,sum);
}
for (;k;--k) if (u[c2[k]]) u[c2[k]]=false;
} void isort1(int ax)
{
register int i,j;
for (i=;i<=tp1;++i)
if (a[ax].x<a[c1[i]].x) break;
++tp1;
for (j=tp1;j>i;--j) c1[j]=c1[j-];
c1[i]=ax;
}
void isort2(int ax)
{
register int i,j;
for (i=;i<=tp2;++i)
if (a[ax].y<a[c2[i]].y) break;
++tp2;
for (j=tp2;j>i;--j) c2[j]=c2[j-];
c2[i]=ax;
}
bool cmp1(const meg& a,const meg& b) {return a.z<b.z;} int main()
{
register int i,j;
n=read(); A=read(); B=read(); C=read();
for (i=;i<=n;++i)
{
a[i].x=read(); a[i].z=read();
a[i].y=1LL*a[i].x*A+1LL*a[i].z*B;
}
sort(a+,a+n+,cmp1);
for (i=n;i;i=j)
{
for (j=i;j&&a[j].z==a[i].z;--j)
isort1(j),isort2(j);
solve(1LL*a[i].z*B+C);
}
printf("%d",ans);
}

Last Word

  小C的O(n^2logn)做法(BZOJ上总时限为3s):

  O(n^2)做法(对比):

  常数小就是舒服.jpg

[BZOJ]1071 组队(SCOI2007)的更多相关文章

  1. BZOJ 1071组队

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1071 题目很好,居然写了很久,题解找了真多: 主要两种做法: O(n^2lgn),通过优先 ...

  2. BZOJ 1071 [SCOI2007]组队

    1071: [SCOI2007]组队 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 1330  Solved: 417[Submit][Status][ ...

  3. BZOJ.1071.[SCOI2007]组队(思路)

    题目链接 三个限制: \(Ah-AminH+Bv-BminV\leq C\ \to\ Ah+Bv\leq C+AminH+BminV\) \(v\geq minV\) \(h\geq minH\) 记 ...

  4. 【BZOJ】1070: [SCOI2007]修车

    1070: [SCOI2007]修车 Description 同 一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的.现在需 ...

  5. BZOJ 1066 【SCOI2007】 蜥蜴

    Description 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外. 每行每列中相邻石柱的距离为$1$,蜥蜴的跳跃距离是d,即蜥蜴可以跳 ...

  6. 【BZOJ】1074: [SCOI2007]折纸origami

    http://www.lydsy.com/JudgeOnline/problem.php?id=1074 题意:一开始有一个左上角是(0,100),右下角是(100,0)的纸片,现在可以沿有向直线折n ...

  7. 【BZOJ】1069: [SCOI2007]最大土地面积(凸包+旋转卡壳)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1069 显然这四个点在凸包上,然后枚举两个点找上下最大的三角形即可. 找三角形表示只想到三分QAQ.. ...

  8. 【BZOJ】1070: [SCOI2007]修车(费用流+特殊的技巧)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1070 好神的题!!!orz 首先我是sb不会拆点..... 首先,每一个技术人员维修车辆都有一个先后 ...

  9. 【BZOJ】1067: [SCOI2007]降雨量(rmq+变态题)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1067 好不爽,弄了一个晚上. 好不爽. 还是照着别人程序拍着看的!!! 噗 这题很变态. 首先,我没 ...

随机推荐

  1. djangoueditor 集成xadmin

    1.安装Python3兼容版本 https://github.com/twz915/DjangoUeditor3/ 2.model加入字段 from DjangoUeditor.models impo ...

  2. 如何减小ios安装包大小

    以前的老文章了,搬到cnblog 更小的安装包意味着更快的下载安装速度,也往往意味着更快的加载运行速度,是优化ios应用的一个重要方面,本文主要参考<减小iOS应用程序的大小>,在实际测试 ...

  3. VS2005 与虚拟机的那点事

      好不容易把VS2008装上了,每次F5编译的时候,程序自动退出,意外的是VS2005也是同样的结果.好在有像我一样的好心人,愿意把解决的方法与大家共享.     经过搜索找到了答案,原来是VMwa ...

  4. vue的简单tab

    <!DOCTYPE html><html lang="en"> <head> <meta charset="UTF-8" ...

  5. axios封装

    前言 作为出入vue的小萌新,我在写请求的时候,也是毫不犹豫写了ajax,结果肯定是不行的... Vue 原本有一个官方推荐的 ajax 插件 vue-resource,但是自从 Vue 更新到 2. ...

  6. Mysql-5.7.21安装配置

    搞开发多年,其实MySql前前后后安装配置了无数次,但是每次都需要到网上搜教程,折腾半天才搞定,这次索性把整个过程全部记录下来,以便以后查阅. 下载 到MySql官网,导航找到DOWNLOADS> ...

  7. js window

    window对象: browser object mode :bom对象. bom提供了独立于内容而与浏览器窗口进行交互的对象. bom主要用于管理窗口与窗口之间的通讯,因此其核心对象是window ...

  8. margin-top塌陷

    margin-top 塌陷 在两个不浮动的盒子嵌套时候,内部的盒子设置的margin-top会加到外边的盒子上,导致内部的盒子margin-top设置失败,解决方法如下: 1.外部盒子设置一个边框: ...

  9. 一日一练-CSS-CSS 居中

    特别声明:此篇文章内容来源于@CHRIS COYIER 的Centering in CSS:A Complete Guide 子曰:CSS 居中是一个非常常见的问题,无论是在项目中,还是在各种面试资料 ...

  10. 1.UTF8字符集csv文件在oracle下乱码问题处理

    1.问题描述 在excel中生成了一个UTF-8编码格式的csv文件准备导入数据库,在notpad++下打开显示正常,编码集为UTF-8,通过pl/sql dev导入oracle是出现乱码,此时初步推 ...