前言(膜法):

早上10点多开始膜的,然后到中午交了一发,感觉膜法不对啊!然后就兴起小窗了一发管理员,然后管理员给我发了in,out数据。。。可是太大并没有什么可取性。。。

还是自己试,然后发现自己搞的案例都过,后面放着不玩了,然后队友给了我一题以前做过的dfs写,然后写了以后T了,后面我就跟他讲这道题。。。讲完好我说我的方法,他硬是不懂我的尺取,然后搞了一个破案例我模拟发现,卧槽我左指针移的时候发现,区间突然没有取前m最大惹,后面在左指针移的时候改了一下,gg,wa的。然后继续测,继续wa。然后发现噢噢噢噢,那样子搞的!始终都要前m大,然后就这样了,膜了一发过了。。。破水题,坑了一天,不过事后发现以后做题要对重要条件特别照顾,始终照顾。然后CF也没打。。。万事大吉,然后就和女朋友去散步了。

题意:

先选一段连续的区间,能够免费m个,免费是任意位置,求一个获得价值最大;

思路:

重点就是在于怎么搞出一个区间的前m大,而且是始终都要。

尺取,对区间里的数进行分类,一类是免费,一类是付钱,那我肯定是免费最贵的,因为最终我的钱多呀!

然后具体操作是两个优先队列搞的,一个队列是付钱的最大,一个队列是免费的最小,这样维护复杂度还好吧。

//#include <bits/stdc++.h>
#include<iostream>
#include<cstdio>
#include<queue>
#include<string.h>
#include<algorithm>
using namespace std;
typedef long long LL;
typedef pair<int,int> PII; const int N=1e5+10;
struct asd{
int id,w;
friend bool operator< (asd n1,asd n2)
{
if(n1.w==n2.w) return n1.id>n2.id;
return n1.w>n2.w;
}
}; struct dsa{
int id,w;
friend bool operator< (dsa n1,dsa n2)
{
if(n1.w==n2.w) return n1.id>n2.id;
return n1.w<n2.w;
}
}; int a[N],b[N],sum[N];
bool vis[N];
priority_queue<asd>q; //区间内免费的物品
priority_queue<dsa>p; //区间内花费的物品
int cost,val,out;
dsa have(int s)
{
dsa now;
while(!p.empty())
{
if(p.top().id<s)
p.pop();
else
break;
}
if(!p.empty())
{
now=p.top();
return now;
}
now.id=0;
return now;
} asd get_q(int s)
{
while(!q.empty())
if(q.top().id<s)
{
q.pop();
out--;
}
else
break;
asd now;
now=q.top();
return now;
} int main()
{
int T,n,m,k;
scanf("%d",&T);
while(T--)
{
while(!q.empty())
q.pop();
while(!p.empty())
p.pop();
scanf("%d%d%d",&n,&m,&k);
for(int i=1;i<=n;i++)
scanf("%d",&a[i]);
sum[0]=0;
for(int i=1;i<=n;i++)
{
scanf("%d",&b[i]);
sum[i]=sum[i-1]+b[i];
vis[i]=false;
}
asd now,nex;
dsa nnn,mmm;
int s,t;
out=0; //out代表,在队列里的实际已经出队的元素个数
cost=0; //代表花费。
val=0; //代表得的价值。
s=t=1;
while(s<=n)
{
while(t<=n)
{
if((q.size()-out)<m)
{
nnn.id=t;nnn.w=a[t];p.push(nnn);
cost+=nnn.w;
mmm=have(s);
cost-=mmm.w;
now.id=mmm.id;now.w=mmm.w;
vis[now.id]=1;
p.pop();
q.push(now);
val=max(val,sum[t]-sum[s-1]);
t++;
}
else if((q.size()-out)==m)
{
now=get_q(s);
if(cost+a[t]>k&&cost+now.w>k)
break; nnn.id=t;nnn.w=a[t];p.push(nnn);
cost+=a[t];
mmm=have(s);
if(mmm.w>now.w)
{
cost-=mmm.w;
cost+=now.w;
q.pop();
p.pop();
nnn.id=now.id;nnn.w=now.w;
vis[nnn.id]=0;
p.push(nnn);
nex.id=mmm.id;nex.w=mmm.w;
vis[nex.id]=1;
q.push(nex);
}
val=max(val,sum[t]-sum[s-1]);
t++;
}
else break;
}
//printf("%d %d\n",s,t);
//printf("%d\n",val);
if(vis[s])
{
vis[s]=false;
out++;
}
else
cost-=a[s];
s++;
}
printf("%d\n",val);
}
return 0;
}
/*
100
6 1 4
5 3 2 4 1 6
2 4 3 1 6 5
5 1 6
1 2 5 4 3
2 2 5 4 8
5 2 6
1 2 5 4 3
2 2 5 4 8
6 2 4
5 3 2 4 1 6
2 4 3 1 6 5
6 2 4
1 7 1 7 1 6
2 4 3 1 6 3
6 2 4
1 7 1 7 1 6
2 4 3 1 6 3
5 2 2
1 2 5 4 3
2 2 5 4 8
5 1 1
8 5 4 3 2
1 2 3 4 5
4 1 3
4 2 2 3
3 2 4 5 */

玲珑OJ1088【蜜汁尺取】的更多相关文章

  1. Gym 100703I---Endeavor for perfection(尺取)

    题目链接 http://codeforces.com/problemset/gymProblem/100703/I Description standard input/outputStatement ...

  2. NOJ 1072 The longest same color grid(尺取)

    Problem 1072: The longest same color grid Time Limits:  1000 MS   Memory Limits:  65536 KB 64-bit in ...

  3. hdu 4123 Bob’s Race 树的直径+rmq+尺取

    Bob’s Race Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Probl ...

  4. Codeforces Round #116 (Div. 2, ACM-ICPC Rules) E. Cubes (尺取)

    题目链接:http://codeforces.com/problemset/problem/180/E 给你n个数,每个数代表一种颜色,给你1到m的m种颜色.最多可以删k个数,问你最长连续相同颜色的序 ...

  5. poj2566尺取变形

    Signals of most probably extra-terrestrial origin have been received and digitalized by The Aeronaut ...

  6. poj2100还是尺取

    King George has recently decided that he would like to have a new design for the royal graveyard. Th ...

  7. hdu 6231 -- K-th Number(二分+尺取)

    题目链接 Problem Description Alice are given an array A[1..N] with N numbers. Now Alice want to build an ...

  8. Codeforces 939E Maximize! (三分 || 尺取)

    <题目链接> 题目大意:给定一段序列,每次进行两次操作,输入1 x代表插入x元素(x元素一定大于等于之前的所有元素),或者输入2,表示输出这个序列的任意子集$s$,使得$max(s)-me ...

  9. cf1121d 尺取

    尺取,写起来有点麻烦 枚举左端点,然后找到右端点,,使得区间[l,r]里各种颜色花朵的数量满足b数组中各种花朵的数量,然后再judge区间[l,r]截取出后能否可以供剩下的n-1个人做花环 /* 给定 ...

随机推荐

  1. MySQL 存储过程 (3)

    以下介绍下像数据库循环插入数据操作 第一步:建立存储过程用到的信息表

  2. [不好分类]iphone手机激活错误的处理过程

    同事一台iphone 6s手机,重启后显示无法激活.(欢迎访问viphhs,欢迎转载.https://www.cnblogs.com/viphhs) 百度后尝试更换了手机卡,重新连接wifi,都不能恢 ...

  3. XML 解析错误:找不到根元素

    大家在开发web项目的过程中,可能会遇到“XML 解析错误:找不到根元素”这么一个问题,引起这个问题的原因可能有很多种,在这儿我只是跟大家分享一下我遇到一种情况. 1.项目背景描述 extjs 结合a ...

  4. SPOJ7258

    传送门 这题可以参考平衡树求第k大的过程,需要预处理一下从当前节点往下走能走出多少个子串. 原本准备存个图用反向的topsort,发现极为麻烦,看了别人的代码后发现,他们按step大小用了基排,省了很 ...

  5. Codeforces Round #173 (Div. 2) E. Sausage Maximization —— 字典树 + 前缀和

    题目链接:http://codeforces.com/problemset/problem/282/E E. Sausage Maximization time limit per test 2 se ...

  6. <ZZ>linux yum命令详解

    http://www.cnblogs.com/chuncn/archive/2010/10/17/1853915.html yum(全称为 Yellow dog Updater, Modified)是 ...

  7. ansible管理windows实践

    一.前言 近期打算搞搞自动部署,因为是windows服务器,一些工具和系统支持都不是太好.最后发现ansible比较火,最重要的是他支持windows.本文主要就ansible 在windows使用环 ...

  8. Linux-Bond-Configure

    Centos 6.6 1. modify /etc/modprobe.d/bond.conf alias bond0 bonding 2. config eth0 & eth1 cat /et ...

  9. [ZJOI 2013] K大数查询

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=3110 [算法] 整体二分 + 线段树 时间复杂度 : O(NlogN ^ 2) [代 ...

  10. 操作 AutoIT:界面与自动化操作结合来简化日常劳动: .Net Reactor验证License,设置License,创建License,截图AutoIt自动化实现。(六)

    自动化操作的稳定性,便利性虽然已经满足了要求,但是页面上呈现的按钮太多了,可以做的更加简单一些. 1. 简化页面的按钮,把5个按钮减少至3个,把Display HID按钮功能整合到create lic ...