洛谷 P3143 [USACO16OPEN]钻石收藏家Diamond Collector 题解
P3143 [USACO16OPEN]钻石收藏家Diamond Collector
题目描述
Bessie the cow, always a fan of shiny objects, has taken up a hobby of mining diamonds in her spare time! She has collected NN diamonds (N \leq 50,000N≤50,000) of varying sizes, and she wants to arrange some of them in a pair of display cases in the barn.
Since Bessie wants the diamonds in each of the two cases to be relatively similar in size, she decides that she will not include two diamonds in the same case if their sizes differ by more than KK (two diamonds can be displayed together in the same case if their sizes differ by exactly KK). Given KK, please help Bessie determine the maximum number of diamonds she can display in both cases together.
奶牛Bessie很喜欢闪亮亮的东西(BalingBaling),所以她喜欢在她的空余时间开采钻石!她现在已经收集了N颗不同大小的钻石(N<=50,000),现在她想在谷仓的两个陈列架上摆放一些钻石。
Bessie想让这些陈列架上的钻石保持相似的大小,所以她不会把两个大小相差K以上的钻石同时放在一个陈列架上(如果两颗钻石的大小差值为K,那么它们可以同时放在一个陈列架上)。现在给出K,请你帮Bessie确定她最多一共可以放多少颗钻石在这两个陈列架上。
输入格式
The first line of the input file contains \(N\) and \(K\) \((0 \leq K \leq 1,000,000,000)\).
The next \(N\) lines each contain an integer giving the size of one of the
diamonds. All sizes will be positive and will not exceed \(1,000,000,000\).
输出格式
Output a single positive integer, telling the maximum number of diamonds that
Bessie can showcase in total in both the cases.
输入输出样例
输入 #1
7 3
10
5
1
12
9
5
14
输出 #1
5
【思路】
排序 + 双指针
【前缀思想】
很有意思的一道题目
这个需要找两组差不超过k的并且和最大的序列
因为需要差不超过k,
所以可以先将序列排一下序
然后就成为了有序的序列(很显然对吧)
这样就可以用双指针记录头和尾
然后只要头和尾的差小于等于k
就可以尝试一下这个区间能不能再扩大
所以可以很简单的就用双指针找出最长的差小于等于k的序列
【中心思想】
但是,这道题目有两个陈列架
所以找出一个最大的是不行的
而且找出次大的和最大的加起来也是不可行的
因为不保证最大和次大的区间不重叠
所以可以正序扫一遍然后找出
到每一个点之前最长的差小于等于k的序列
然后再倒序找一遍找出
到每一个点之后最长的差小于等于k的序列
【小细节】
这样,只需要再枚举一遍每一个点
然后比较前后加起来的和最大的就是了
不过,如果出现了前后最大的刚好重叠在枚举到的这个点
那么加起来的和就会重复一次
而且是不合法的
毕竟你不能把一个宝石放在两个陈列架上
所以就有了后面在比较时候的:
M = max(M,qian[i] + hou[i + 1]);
这样就不会出现一个点刚好是两个区间的交点的情况了
【完整代码】
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
const int Max = 50005;
int a[Max];
int qian[Max];
int hou[Max];
int main()
{
	int n,k;
	cin >> n >> k;
	for(register int i = 1;i <= n;++ i)
		cin >> a[i];
	sort(a + 1,a + 1 + n);
	for(register int l = 1,r = 1;r <= n;++ r)
	{
		while(a[r] - a[l] > k && l <= r)l ++;
		qian[r] = max(qian[r - 1],r - l + 1);
	}
	for(register int r = n,l = n;l >= 1;l --)
	{
		while(a[r] - a[l] > k && l <= r)r --;
		hou[l] = max(hou[l] + 1,r - l + 1);
	}
	int M = 0;
	for(register int i = 1;i < n;++ i)
		M = max(M,qian[i] + hou[i + 1]);
	cout << M << endl;
	return 0;
}
												
											洛谷 P3143 [USACO16OPEN]钻石收藏家Diamond Collector 题解的更多相关文章
- 【前缀和】【two-pointer】【贪心】洛谷 P3143 [USACO16OPEN]钻石收藏家Diamond Collector 题解
		
解法众多的一道毒瘤题? 题目描述 奶牛Bessie很喜欢闪亮亮的东西(Baling~Baling~),所以她喜欢在她的空余时间开采钻石!她现在已经收集了\(N\)颗不同大小的钻石,现在她想在谷 ...
 - 洛谷 P3143 [USACO16OPEN]钻石收藏家Diamond Collector 解题报告
		
P3143 [USACO16OPEN]钻石收藏家Diamond Collector 题目描述 Bessie the cow, always a fan of shiny objects, has ta ...
 - 洛谷 P3143 [USACO16OPEN]钻石收藏家Diamond Collector
		
题目描述 Bessie the cow, always a fan of shiny objects, has taken up a hobby of mining diamonds in her s ...
 - 洛谷P3143 [USACO16OPEN]钻石收藏家Diamond Collector
		
题目描述 Bessie the cow, always a fan of shiny objects, has taken up a hobby of mining diamonds in her s ...
 - [USACO16OPEN]钻石收藏家Diamond Collector
		
由于相差不超过k才可以放在一起,要判断不超过k这个条件,显然我们需要排序 首先我们需要一个f数组,f[i]意义看代码开头注释, 假设我们可以选择的某一个区间是a[l]~a[r](已排序且最优(最长的意 ...
 - 洛谷P1484 种树&洛谷P3620 [APIO/CTSC 2007]数据备份 题解(堆+贪心)
		
洛谷P1484 种树&洛谷P3620 [APIO/CTSC 2007]数据备份 题解(堆+贪心) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/132 ...
 - 洛谷P3387 【模板】缩点 题解
		
背景 今天\(loj\)挂了,于是就有了闲情雅致来刷\(luogu\) 题面 洛谷P3387 [模板]缩点传送门 题意 给定一个\(n\)个点\(m\)条边有向图,每个点有一个权值,求一条路径,使路径 ...
 - [NOI导刊2010提高&洛谷P1774]最接近神的人  题解(树状数组求逆序对)
		
[NOI导刊2010提高&洛谷P1774]最接近神的人 Description 破解了符文之语,小FF开启了通往地下的道路.当他走到最底层时,发现正前方有一扇巨石门,门上雕刻着一幅古代人进行某 ...
 - [洛谷P1029]最大公约数与最小公倍数问题 题解(辗转相除法求GCD)
		
[洛谷P1029]最大公约数与最小公倍数问题 Description 输入二个正整数x0,y0(2<=x0<100000,2<=y0<=1000000),求出满足下列条件的P, ...
 
随机推荐
- gitlab-runner 安装使用
			
gitlab-runner 安装使用 gitlab-runner 是一个开源的与 gitlab CI 配合使用的项目,用于运行任务,并将结果返回 gitlab 本文通过docker in docker ...
 - LOJ3146 APIO2019路灯(cdq分治+树状数组)
			
每个时刻都形成若干段满足段内任意两点可达.将其视为若干正方形.则查询相当于求历史上某点被正方形包含的时刻数量.并且注意到每个时刻只有O(1)个正方形出现或消失,那么求出每个矩形的出现时间和消失时间,就 ...
 - Spring Boot 入门 - 目录
			
pring Boot 入门 - 进阶篇(3)- 定时任务(@Scheduled) 主要用于定时发送邮件.夜间自动维护等. (1)开启定时任务功能 @Configuration @EnableSched ...
 - C#通用公共类库ZXNetStandardDepot.Common
			
总结了一下写项目中遇到的各种方法,总结前辈们的经验,生成了该类库,引用net standard类库,支持net core/net framework. 使用方法 1.nuget 搜索 ZXNetSta ...
 - 易百教程人工智能python修正-人工智能监督学习(分类)
			
分类技术或模型试图从观测值中得出一些结论. 在分类问题中,我们有分类输出,如“黑色”或“白色”或“教学”和“非教学”. 在构建分类模型时,需要有包含数据点和相应标签的训练数据集. 例如,如果想检查图像 ...
 - c++ 使用torchscript 加载训练好的pytorch模型
			
1.首先官网上下载libtorch,放到当前项目下 2.将pytorch训练好的模型使用torch.jit.trace导出为.pt格式 import torch from skimage import ...
 - Qt 接受拖放
			
第一步:在构造函数里面 添加拖放支持,相当于总开关(注意这里设置之后是整个窗口可以接受拖放) setAcceptDrops(true); 第二步:重写接受拖放相关的虚函数 void dragEnter ...
 - Topshelf+Quartz实现windows任务
			
Topshelf使用示例, HostFactory.Run(x => { x.Service<QuartzStartup>(s => { s.ConstructUsing(na ...
 - CRM-Q模糊查询
			
Q查询-模糊查询 示例一 q=Q() # 实例化一个Q的对象q,我们可以给它加条件 q.children.append(("name","xxx")) # 添加 ...
 - OSI标准协议分析
			
1.各个层的作用 物理层:(physical Layer):物理层负责传送比特(Bit),涉及到接口和传输媒体的机械 电气特性 数据链路层:(data link layer):数据链路层负责传送的帧( ...