[Codeup 25482] Beauty
25482: Beauty
时间限制: 1 Sec 内存限制: 128 MB
献花: 7 解决: 3
[献花][花圈][TK题库]题目描述
一年一度的星哥选美又拉开了帷幕
N个人报名参加选拔,每个人都有着各自的相貌参数和身材参数(不大于10000的正整数)。你的任务是尽可能让更多人被星哥选中,而唯一要求就是,在这只队伍里面的每个人,都需满足以下不等式:
A (H−h)+B(W−w)≤C
其中H和W为这个人的相貌和身材,h和w为选中者中的最小相貌参数和最小身材参数,而A、B、C为三个不大于10000的正的整型常数。
现在请计算星哥最多可以选中多少人。
输入
第一行:一个整数:N
第二行:三个分开的整数:A,B和C
第三行到第N+2行:每行有两个用空格分开的整数,分别表示一个人的相貌参数和身材参数
输出
第一行:最多被选的人数样例输入
8
1 2 4
5 1
3 2
2 3
2 1
7 2
6 4
5 1
4 3样例输出
5提示
第1,2,3,4,7号可以组成一支符合要求的队伍,没有更大的队伍了
这道题第一眼看成离散化然而发现数据范围不大并不需要离散化OwO
对于这题似乎有两种解法, 一种是 $O(n^2log(n))$ 的, 还有一种似乎是 $O(n*w_{max})$ 的. 根据某dalao $wq$ 所言还能用 $CDQ$ 分治水过去w.
这里只讲第二种好了w实际评测中发现时间消耗比第一种少 $30\%$ 左右
首先枚举 $h$, 然后在内层枚举要处理的结点, 这样我们可以得到 $h$ $H$ $W$ 三个值. 结合 $A$ $B$ $C$ 与不等式我们可以计算出要使该要处理的结点被选中所需的最小 $w$ 值. 然后再根据 $W$ 值可以计算出要使该结点要被选中, $w$ 所应当落在的区间. 然后我们在数组中对区间进行差分, 计算完对于某个 $h$ 的所有结点的 $w$ 区间后对差分所得数组求前缀和处理出对于每个 $w$ 值有多少个结点被选中. 然后根据结点信息枚举可能的 $w$ 并对最终结果取 $max$. 对于所有 $n$ 个 $h$ 都计算一下, 然后全局最大值即为最优解.
其中要注意的是: 由于我们所枚举的 $h$ 是最小值, 所以对于 $H$ 值小于我们所枚举的 $h$ 的结点应直接跳过防止影响答案. 而由于 $w$ 是最小值, 则 $B(W-w) \geq 0$ , 所以 $A(H-h) \leq C$ , 所以对于 $A(H-h) > C$ 的情况我们也要直接跳过防止影响答案.
参考代码如下:
GitHub
#include <queue>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm> const int MAXN=; struct Point{
int x;
int y;
Point(int x=,int y=){
this->x=x;
this->y=y;
}
}; int n;
int m;
int l=,r=;
int xa,ya,xb,yb;
Point q[];
int dis[MAXN][MAXN];
int melt[MAXN][MAXN];
bool visited[MAXN][MAXN]; void BFS();
void gch(char&);
void Initialize();
void SPFA(int,int); int main(){
Initialize();
BFS();
SPFA(xa,ya);
printf("%d\n",dis[xb][yb]);
return ;
} void SPFA(int x,int y){
memset(visited,,sizeof(visited));
dis[x][y]=;
q[r++]=(Point(x,y));
visited[x][y]=true;
while(l<r){
x=q[l].x;
y=q[l].y;
l++;
visited[x][y]=false;
if(x>&&dis[x][y]<dis[x-][y]&&dis[x-][y]!=melt[x-][y]){
dis[x-][y]=std::max(dis[x][y],melt[x-][y]);
if(!visited[x-][y]){
visited[x-][y]=true;
q[r++]=(Point(x-,y));
}
}
if(x<n&&dis[x][y]<dis[x+][y]&&dis[x+][y]!=melt[x+][y]){
dis[x+][y]=std::max(dis[x][y],melt[x+][y]);
if(!visited[x+][y]){
visited[x+][y]=true;
q[r++]=(Point(x+,y));
}
}
if(y>&&dis[x][y]<dis[x][y-]&&dis[x][y-]!=melt[x][y-]){
dis[x][y-]=std::max(dis[x][y],melt[x][y-]);
if(!visited[x][y-]){
visited[x][y-]=true;
q[r++]=(Point(x,y-));
}
}
if(y<m&&dis[x][y]<dis[x][y+]&&dis[x][y+]!=melt[x][y+]){
dis[x][y+]=std::max(dis[x][y],melt[x][y+]);
if(!visited[x][y+]){
visited[x][y+]=true;
q[r++]=(Point(x,y+));
}
}
}
} void BFS(){
memset(visited,,sizeof(visited));
while(l<r){
int x=q[l].x;
int y=q[l].y;
++l;
if(x>&&!visited[x-][y]&&melt[x][y]+<melt[x-][y]){
melt[x-][y]=melt[x][y]+;
visited[x-][y]=true;
q[r++]=(Point(x-,y));
}
if(x<n&&!visited[x+][y]&&melt[x][y]+<melt[x+][y]){
melt[x+][y]=melt[x][y]+;
visited[x+][y]=true;
q[r++]=(Point(x+,y));
}
if(y>&&!visited[x][y-]&&melt[x][y]+<melt[x][y-]){
melt[x][y-]=melt[x][y]+;
visited[x][y-]=true;
q[r++]=(Point(x,y-));
}
if(y<m&&!visited[x][y+]&&melt[x][y]+<melt[x][y+]){
melt[x][y+]=melt[x][y]+;
visited[x][y+]=true;
q[r++]=(Point(x,y+));
}
}
} void Initialize(){
char ch;
memset(dis,0x3F,sizeof(dis));
memset(melt,0x3F,sizeof(melt));
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++){
for(int j=;j<=m;j++){
gch(ch);
if(ch=='.'){
q[r++]=(Point(i,j));
melt[i][j]=;
visited[i][j]=true;
}
else if(ch=='L'){
q[r++]=(Point(i,j));
melt[i][j]=;
visited[i][j]=true;
if(xa==){
xa=i;
ya=j;
}
else{
xb=i;
yb=j;
}
}
}
}
} void gch(char& target){
do{
target=getchar();
}while(target!='.'&&target!='X'&&target!='L');
}
Backup
以及日常图包w
[Codeup 25482] Beauty的更多相关文章
- [Codeup 25482]选美
[Codeup 25482 ]选美 题目 一年一度的星哥选美又拉开了帷幕 N个人报名参加选拔,每个人都有着各自的相貌参数和身材参数(不大于 10000 的正整数).你的任务是尽可能让更多人被星哥选中, ...
- 暑假集训D13总结
考试 又炸掉了= = 本来看着题就一脸茫然,默默的打暴力骗分,然后就交了卷= = 重要的是,在本机跑的毫无障碍的T3程序竟然在评测机CE啊喂,35分就没了啊喂(这可是比我现在分还高= =) 内心几近崩 ...
- poj 2187 Beauty Contest(凸包求解多节点的之间的最大距离)
/* poj 2187 Beauty Contest 凸包:寻找每两点之间距离的最大值 这个最大值一定是在凸包的边缘上的! 求凸包的算法: Andrew算法! */ #include<iostr ...
- hdu-5496 Beauty of Sequence(递推)
题目链接: Beauty of Sequence Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K (Java ...
- POJ2187 Beauty Contest
Description Bessie, Farmer John's prize cow, has just won first place in a bovine beauty contest, ea ...
- DP ZOJ 3872 Beauty of Array
题目传送门 /* DP:dp 表示当前输入的x前的包含x的子序列的和, 求和方法是找到之前出现x的位置(a[x])的区间内的子序列: sum 表示当前输入x前的所有和: a[x] 表示id: 详细解释 ...
- 【POJ】2187 Beauty Contest(旋转卡壳)
http://poj.org/problem?id=2187 显然直径在凸包上(黑书上有证明).(然后这题让我发现我之前好几次凸包的排序都错了QAQ只排序了x轴.....没有排序y轴.. 然后本题数据 ...
- Where does beauty come from?
One more question, rational beauty should come from a dedicated brain and mind. Should there be more ...
- zoj The 12th Zhejiang Provincial Collegiate Programming Contest Beauty of Array
http://acm.zju.edu.cn/onlinejudge/showContestProblem.do?problemId=5496 The 12th Zhejiang Provincial ...
随机推荐
- Spring MVC 使用kaptcha生成验证码
Spring MVC 使用kaptcha生成验证码 1.下载kaptcha-2.3.2.jar(或直接通过该文章附件下载) http://code.google.com/p/kaptcha/downl ...
- js empty() vs remove()
转自:jQuery empty() vs remove() empty() will remove all the contents of the selection. remove() will r ...
- tmux快捷键汇总(常用)
会话外操作: tmux new -s <name-of-my-session> 在会话外创建一个新的会话 tmux ls 在会话外获取会话列表 tmux a(attach) -t < ...
- CPU漏洞补丁修复导致KeServiceDescriptorTable获取变更
一.前言 2018年元旦,出现的cpu的漏洞,可以在windows环三直接读取内核数据,windows对该漏洞提供补丁,补丁增加了一个页表,对应的内核处理也增加了,接下来我们看下补丁修复的表象以及对K ...
- free 和 delete 把指针怎么了
使用free或delete之后,只是把指针所指的内容给释放掉,但是指针并没有被干掉,还是指向原来位置(并不是执行NULL),此时指针指向的内容为垃圾,被称为“野指针”. 举例说明几个重要容易迷糊的特征 ...
- java调用C++代码
一.在要使用到C++代码的类文件中声明一个native方法,例如: public class TestNative{ public native void test(); } 二.javac编译此ja ...
- RxJS库
介绍 RxJS是一个异步编程的库,同时它通过observable序列来实现基于事件的编程.它提供了一个核心的类型:Observable,几个辅助类型(Observer,Schedulers,Subje ...
- 选择适用才最好 盘点MySQL备份方式
我们要备份什么? 一般情况下, 我们需要备份的数据分为以下几种 数据 二进制日志, InnoDB事务日志 代码(存储过程.存储函数.触发器.事件调度器) 服务器配置文件 备份工具 这里我们列举出常用的 ...
- iOS开发笔记18:一些编译、开发调试、打包的细节整理
1.以链库的方式引用第三方库 一些特殊场景可能会要求使用链库的方式使用第三方库,大体设置如下: ①Other Linker Flags里进行设置,格式为-l+库名称 ②Libray Search Pa ...
- 全面了解HTTP和HTTPS
序言 Http和Https属于计算机网络范畴,但作为开发人员,不管是后台开发或是前台开发,都很有必要掌握它们. 在学习Http和Https的过程中,主要是参考了阮一峰老师的博客,讲的很全面,并且通俗易 ...