poj2008

题意:给定一些点的坐标(hi,wi),要选出一个点集,使得集合所包含的点数最多,且符合A*(H-h) + B*(W-w) <= C,h为集合中最小h,w为点集中最小w。

分析:我们是要找到这样的点集,hi>=h,wi>=w,A*(hi-h) + B*(wi-w) <= C。根据线性规划知识,这些点都在一个直角三角形内,两条直角边长度为cw=C/A,ch=C/B。我们的问题转化为用这样一个三角形最多能框住多少点,且根据题意w,h为点集坐标最小值,即三角形两条直角边上都要有点。

我们的做法是,枚举n个点,对于每个点,先使其处于三角形的直角顶点(左下角),然后向下平移三角形框,每次多加进一个点且要保证我们本次枚举的那个点不出框。看最多的时候能有多少个点在框内。每向下推一下要加进哪些点,除去哪些点我们用一个巧妙的方法来处理。我们用跨越三角形底边的点数减去跨域三角形斜边的点数。我们利用一个将所有点按高度排序的数组,和一个指向该数组的指针,每次枚举一个点,就把指针指向第一位(默认所有点都在线框底边以下),每推一下,就将指针向后移动一些,看有几个点由线框底边以下变为以上。同理我们需要一个按k=A*hi  + B*wi排序的数组。用相同的方法来统计有多少点跨域了斜边。注意不是所有指针掠过的点都是跨越的,需要判断他们的横坐标是否在范围内。

ContractedBlock.gifExpandedBlockStart.gifView Code
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <algorithm>
using namespace std;

#define maxn 1005

struct Point
{
int w, h, k;
}point[maxn], *sort_h[maxn], *sort_k[maxn];

int n, cw, ch, A, B, C;
int ans, cnt, hnum, knum;

bool cmph(Point *a, Point *b)
{
return a->h > b->h;
}

bool cmpk(Point *a, Point *b)
{
return a->k > b->k;
}

void input()
{
scanf("%d", &n);
scanf("%d%d%d", &A, &B, &C);
ch = C / A;
cw = C / B;
for (int i = 0; i < n; i++)
{
scanf("%d%d", &point[i].h, &point[i].w);
point[i].k = A * point[i].h + B * point[i].w;
sort_h[i] = &point[i];
sort_k[i] = &point[i];
}
}

int cal(int h, int w)
{
for (; hnum < n && sort_h[hnum]->h >= h; hnum++)
if (sort_h[hnum]->w >= w && sort_h[hnum]->w <= w + cw)
cnt++;
int k = A * h + B * w + C;
for (; knum < n && sort_k[knum]->k > k; knum++)
if (sort_k[knum]->w >= w && sort_k[knum]->w <= w + cw)
cnt--;
return cnt;
}

void work(int a)
{
cnt = hnum = knum = 0;
int w = sort_h[a]->w;
int h = sort_h[a]->h;
for (int i = a; i < n && sort_h[i]->h >= h - ch; i++)
if (sort_h[i]->w >= w && sort_h[i]->w <= w + cw)
ans = max(ans, cal(sort_h[i]->h, w));
}

int main()
{
//freopen("t.txt", "r", stdin);
input();
sort(sort_h, sort_h + n, cmph);
sort(sort_k, sort_k + n, cmpk);
ans = 0;
for (int i = 0; i < n; i++)
work(i);
printf("%d\n", ans);
return 0;
}



本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/548772.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Git右键没有Git Bash Here的解决办法

好长一段时间没有使用Git了&#xff0c;今天想用git在码云上下载东西&#xff0c;但是突然发现右键没有Git Bash Here了&#xff0c;然后在网上搜索了一番&#xff0c;然后解决了。 解决方法&#xff1a; winR 打开运行小窗口&#xff0c;在 “ 运行 ” 中输入‘ regedit ’&…

对HashMap数据结构的理解——加载因子和初始容量

先看源码&#xff1a; 解释一下位移运算&#xff1a; 1<<4 是位移运算的表示&#xff0c;为十进制16 1的二进制表示&#xff1a;1 左移4位之后的二进制表示为B&#xff08;10000&#xff09; D&#xff08;16&#xff09; 更简单的计算方法就是 1<< n 等效于 1 乘…

“习惯性思维”引起的血案

好久没有更新了&#xff0c;一客户因为IT规划问题&#xff0c;需要将Citrix服务器迁到新的域&#xff0c;Citrix服 务器需要重新配置。但是当我重新配置完站点后&#xff0c;发现无论如何都登录不了。 错误截图&#xff1a; 我按照传统的思路来解决问题&#xff0c; 1、查看服务…

剑指 Offer 52. 两个链表的第一个公共节点

剑指 Offer 52. 两个链表的第一个公共节点 输入两个链表&#xff0c;找出它们的第一个公共节点。 思想&#xff1a;双指针法&#xff0c;浪漫相遇 public static ListNode getIntersectionNode(ListNode headA, ListNode headB) {ListNode pointA headA;ListNode pointB he…

IDEA查看源码时总是出现.class而不是.java源码(解决办法)

自己安装的JDK8里面就有源码&#xff0c;就是图中的src.zip&#xff0c;我还傻乎乎的跑去下。 我参考下面这个链接解决了这个问题&#xff1a; https://www.it610.com/article/1283023085871579136.htm 特别注意其中的一句话&#xff1a;把SDKs中多余的jdk删掉留一个就好&am…

ASP“.NET研究”.NET中的认证与授权

用户认证 .net提供了3种用户认证的方式&#xff0c;分别是Windows,Forms&#xff0c;Passport。这几种形式的定义可以在网站根目录下Web.config中的authentication节点中看见。Windows是默认的验证形式&#xff0c;它是根据机器的访问权限来判断的。Passport是微软提供的一种验…

用NuGet掌管你的Vi“.NET研究”sual Studio扩展

如果你使用Visual Studio 2010&#xff0c;那么 NuGet 可以使你的生活更加美好。当你项目里要引用到的一些库时候&#xff0c;比如JQuery 库或者 NHibernate, NUnit, log4net 你就可以考虑使用NuGet。它可以辅助你安装或者更新这些库。 当然我不得不继续说下去从安装到使用&…

cmd窗口使用python提示“Python not found”,可能是环境变量配置的原因

问题1 打开命令行窗口使用python命令无法直接进入python环境&#xff0c;但是从python的安装目录下就可以进去 问题原因 没有配置系统环境变量&#xff0c;需要把python安装路径添加到path环境变量中 环境变量配置&#xff0c;可以参考菜鸟教程 问题2 配置了环境变量之后…

无法打开caffe.pb.h, no such file or directory错误

问题&#xff1a; 使用VS2013生成caffe解决方案的过程中&#xff0c;出现 无法打开caffe.pb.h&#xff0c;no such file or directory ,解决方案 &#xff1a; 参考博客&#xff1a;[caffe] 无法打开caffe.pb.h, no such file or directory错误 博客地址&#xff1a;https://b…

NuGet Error:Unable to find version ‘0.3.3.0‘ of package ‘glog.overlay-x64_v120_Release_dynamic‘.

问题&#xff1a; 使用VS2013生成caffe解决方案时&#xff0c;报错NuGet Error:Unable to find version 0.3.3.0 of package glog.overlay-x64_v120_Release_dynamic. 解决方案&#xff1a; 一、参考文章里面的回答&#xff1a; 链接&#xff1a;NuGet error while buildin…

【caffe】找不到gpu/mxGPUArray.h

问题原因&#xff1a; Microsoft 的github貌似更新了matcaffe中的caffe_.cpp文件&#xff0c;第十六行添加了对gpu/mxGPUArray.h的引用 解决方法 是将本机Matlab的该文件夹复制到Caffe项目文件的对应位置。 具体方法 在你的matlab文件下面搜索mxGPUArray.h文件&#xff0c…

4 error C2220: 警告被视为错误 - 没有生成“object”文件 (..\..\src\caffe\util\math_functions.cpp)

在VS2013上编译caffe时遇到如下问题&#xff1a; 错误原因&#xff1a; 原因是该文件的代码页为英文&#xff0c;而我们系统中的代码页为中文。 解决方法&#xff1a; 将源码转化为正确的编码方式 用VS2013打开对应的文档&#xff0c;文件->打开->选择该cpp&#xff0…

技术人员如何转型为产品经理

技术人员如何转型为产品经理不知道是不是所有的公司开会都是这样&#xff0c;以时间长短作为衡量会议重要性的标准。周扬被郭姐姐叫去开会&#xff0c;9点半开始&#xff0c;直到快12点了&#xff0c;他才满脸愁容地回到办公室。放下笔记本&#xff0c;周扬站到办公室中间&…

错误 4 error C2220: 警告被视为错误 - 没有生成“object”文件

报错内容&#xff1a; 复制第一行的错误内容&#xff1a; 错误 4 error C2220: 警告被视为错误 - 没有生成“object”文件 D:\Program Files\NugetPackages\boost.1.59.0.0\lib\native\include\boost\format\alt_sstream_impl.hpp 1 1 libcaffe 复制会发现他给出了没有生成obje…

未定义变量或函数caffe_()

该错误是使用matlab 运行classification_demo产生的 三要素仔细检查 一、添加系统环境变量 把 \caffe-master\Build\x64\Release添加到系统环境变量中 二、添加 Caffe 路径 打开 MATLAB&#xff0c;在命令窗口输入pathtool&#xff0c;添加 Caffe 路径&#xff0c;主要是添…

围观窗体与组件03 - 零基础入门学习Delphi25

围观窗体与组件03 让编程改变世界 Change the world by program 围观按钮型组件 Button、BitBtn、SpeedButton的一些区别 区别一&#xff1a;Button 不能显示位图 区别二&#xff1a;SpeedButton 没有焦点&#xff0c;一般用于工具栏按钮 区别三&#xff1a;BitBtn 有 kind…

LaTeX的安装教程及问题记录

安装教程 我的安装过程参考的博客&#xff1a; LaTeX的安装教程&#xff08;Texlive 2020 TeX studio&#xff09; 遇到的问题 TLUtils::install_packages: Failed to install texlive.infra.win32 Installation failed. 解决办法&#xff1a; 将安装包解压路径全部放置在英…

Extra }, or forgotten lendgroup. \makecover

问题&#xff1a; 下载UESTC 的硕士学位论文Latex模板编译后&#xff0c;遇到报错&#xff1a; 产生原因&#xff1a; 问题产生原因&#xff0c;是我偶然间发现&#xff0c;在该语句前面部分的导言区错误表示了&符号。 也就是说&#xff0c;latex中需要注意特殊符号的表…

QTP测试脚本

今天看了QTP参数化写了第一个测试脚本&#xff0c;居然能成功运行了&#xff0c;挺有成就感的&#xff0c;写下来了&#xff0c;嘿嘿……&#xff0c;下面进行详细分析&#xff1a; 转载于:https://www.cnblogs.com/hyzhou/archive/2011/11/11/2245904.html

Undefined control sequence. \makecover

问题&#xff1a; 今天刚下载了github上2021年的UESTC硕士学位论文latex模板&#xff0c;直接编译\makecover报错 产生原因&#xff1a; 在begin{document}前面的内容还缺少字段 解决办法&#xff1a; 添加以下字段 \maintitle \degree 专硕需要把master改成promatesr&am…