恩……为什么大家都这么执着于 \(O(n^{2})\) 的复杂度捏?如果接受 \(O(n^{2} + nV)\) 的复杂度,那这题可不是道**题吗( • ̀ω•́ )✧

  首先把所有的人按照身高排个序,然后我们就可以枚举一个人作为身高的最小值。此时,原式

\(A * H + B * V - C <= A * minh + B * minv\) 

我们可以把常量固定一下:

\(S_{x} = A * H_{x} - C - A * minh\)

\(S_{x} + B * V_{x} <= B * minv\)

移项得到 \(V_{x} - minv <= \frac{-S_{x}}{B}\)

不过仅仅满足这一个条件还不够,还有一个限制条件为

\(V_{x} >= minv\)

整理一下,把 minv 作为变量

 \( \frac{-S_{x}}{B} + V_{x} <= minv <= V_{x}\)

 这样我们在 v 的取值范围上差分一下,取最值即可。

  以及虽然复杂度略高,但是鉴于优秀的常数 & 算法内容的操作简单,跑起来很快 :洛谷rank1~

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. #define maxn 1000000
  4. int n, A, B, C, mx, ans, a[maxn];
  5.  
  6. int read()
  7. {
  8. int x = , k = ;
  9. char c; c = getchar();
  10. while(c < '' || c > '') { if(c == '-') k = -; c = getchar(); }
  11. while(c >= '' && c <= '') x = x * + c - '', c = getchar();
  12. return x * k;
  13. }
  14.  
  15. struct node
  16. {
  17. int v, h;
  18. friend bool operator <(const node& a, const node& b)
  19. { return a.h < b.h; }
  20. }P[maxn];
  21.  
  22. void Work(int x)
  23. {
  24. int H = P[x].h, T = H * A;
  25. for(int i = x; i <= n; i ++)
  26. {
  27. int l = max(, P[i].v - (T - A * P[i].h + C) / B);
  28. int r = P[i].v;
  29. if(l > r) continue;
  30. a[l] ++, a[r + ] --;
  31. }
  32.  
  33. for(int i = , tem = ; i <= mx; i ++)
  34. {
  35. a[i] += tem; tem = a[i];
  36. ans = max(ans, a[i]); a[i] = ;
  37. }
  38. }
  39.  
  40. int main()
  41. {
  42. n = read(); A = read(), B = read(), C = read();
  43. for(int i = ; i <= n; i ++)
  44. {
  45. P[i].h = read(), P[i].v = read();
  46. mx = max(mx, P[i].v);
  47. }
  48. sort(P + , P + + n);
  49. for(int i = n; i >= ; i --) Work(i);
  50. printf("%d\n", ans);
  51. return ;
  52. }

【题解】SCOI2007组队的更多相关文章

  1. BZOJ 1071 [SCOI2007]组队

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

  2. 【BZOJ1071】[SCOI2007]组队(神仙题)

    [BZOJ1071][SCOI2007]组队(神仙题) 题面 BZOJ 洛谷 题解 首先把式子整理一下,也就是\(A*h+B*v\le C+A*minH+B*minV\) 我们正常能够想到的做法是钦定 ...

  3. [SCOI2007]组队 差分

    题面:[SCOI2007]组队 题解: 一开始固定H然后找性质找了很久也没有找到任何有用的东西...... 然后大佬告诉我一个神奇的方法... 首先我们化一波式子: 设$H$表示高度的最小值,$V$表 ...

  4. bzoj1071[SCOI2007]组队

    1071: [SCOI2007]组队 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 2472  Solved: 792[Submit][Status][ ...

  5. 1071: [SCOI2007]组队

    1071: [SCOI2007]组队 https://lydsy.com/JudgeOnline/problem.php?id=1071 分析: dp+单调性. A*(hi–minH)+B*(si–m ...

  6. [SCOI2007]组队

    嘟嘟嘟 这题有人说部分分O(n3)暴力,然而我暴力都没写过,调了半天也没用……还是看题解吧 首先,咱把A * ( h – minH ) + B * ( s – minS ) <= C 变个型,得 ...

  7. 1071: [SCOI2007]组队 - BZOJ

    Description NBA每年都有球员选秀环节.通常用速度和身高两项数据来衡量一个篮球运动员的基本素质.假如一支球队里速度最慢的球员速度为minV,身高最矮的球员高度为minH,那么这支球队的所有 ...

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

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

  9. BZOJ1071: [SCOI2007]组队【双指针】【思维好题】

    Description NBA每年都有球员选秀环节.通常用速度和身高两项数据来衡量一个篮球运动员的基本素质.假如一支球队里速度最慢的球员速度为minV,身高最矮的球员高度为minH,那么这支球队的所有 ...

随机推荐

  1. 虚拟机ubuntu使用串口

    1. 电脑的串口默认是在windows系统上,需要把串口转到ubuntu上面,按照下面的步骤先 2. 找到需要使用的串口 3. 在VMWARE里面连接该串口 或者使用方法 4. 成功之后,检查一下ls ...

  2. hdu1874畅通工程续(floyd)

    畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  3. mysql数据库基本操作命令

    1.登录命令 mysql -u root -p "password" 2.列出所有数据库 show databases; 3.使用数据库 use db_name 4.列出数据库中所 ...

  4. Qt-QML-Connections,接受组件信号

    这里还没有什么新的体会.就直接上代码,在上篇一处上改出来的 import QtQuick 2.5 import QtQuick.Controls 1.4 ApplicationWindow { vis ...

  5. python3读取csv文件

    代码如下 import csv with open('D:\\abc\\userinfo.csv',newline='') as f: reader = csv.reader(f) for row i ...

  6. Kotlin Android Extensions: 与 findViewById 说再见 (KAD 04) -- 更新版

    作者:Antonio Leiva 时间:Aug 16, 2017 原文链接:https://antonioleiva.com/kotlin-android-extensions/ 在 Kotlin1. ...

  7. 天平 (Not so Mobile UVA - 839)

    题目描述: 题目思路: 1.DFS建树 2.只有每个树的左右子树都平衡整颗树才平衡 #include <iostream> using namespace std; bool solve( ...

  8. Thunder团队第三周 - Scrum会议6

    Scrum会议6 小组名称:Thunder 项目名称:i阅app Scrum Master:宋雨 工作照片: 代秋彤照相,所以图片中没有该同学. 参会成员: 王航:http://www.cnblogs ...

  9. MyEclipse2013使用总结

    1.myeclipse10中怎样将建的包设置成树形结构或者并列结构. 右上边三角那里进去设置选第一个是显示完整的包名,第二个显示的是树形结构这种方法没效 2.从高版本到项目的低版本的MyEclipse ...

  10. JavaWeb基础 - 会话

    会话概述 什么是会话 简单的理解:用户打开浏览器,点击多个超链接,访问Web服务器上多个资源,然后关闭浏览器,整个过程称之为一次会话. 需要解决的问题 每个用户在使用浏览器与服务器会话的过程中,会产生 ...