洛谷 P3253 [JLOI2013]删除物品 解题报告
P3253 [JLOI2013]删除物品
题目描述
箱子再分配问题需要解决如下问题:
(1)一共有\(N\)个物品,堆成\(M\)堆。
(2)所有物品都是一样的,但是它们有不同的优先级。
(3)你只能够移动某堆中位于顶端的物品。
(4)你可以把任意一堆中位于顶端的物品移动到其它某堆的顶端。若此物品是当前所有物品中优先级最高的,可以直接将之删除而不用移动。
(5)求出将所有物品删除所需的最小步数。删除操作不计入步数之中。
(6)只是一个比较难解决的问题,这里你只需要解决一个比较简单的版本: 不会有两个物品有着相同的优先级,且\(M=2\)
输入输出格式
输入格式:
第一行是包含两个整数\(N1,N2\)分别表示两堆物品的个数。接下来有\(N1\)行整数按照从顶到底的顺序分别给出了第一堆物品中的优先级,数字越大,优先级越高。再接下来的N2行按照同样的格式给出了第二堆物品的优先级。
输出格式:
对于每个数据,请输出一个整数,即最小移动步数。
说明
\(1<=N1+N2<=100000\)
说一下我做这个题的心路历程。
- 汉诺\(n\)塔问题?
- 两个栈?
- 等等,我似不似看错了,这不就是个模拟???
- 好像没错啊...
- 噫?模拟是\(O(n^2)\)?
- 苟不住了估计要跑数据结构
- 噫,我把这一坨挪到另一个上面后它们距离当前栈顶的距离是翻转区间???
- 分......分块?完了不会分块啊
- 瞎画+摸鱼\(ing\)
- 等等,我把两个栈bu~成一个数组后不仅只用挪中间的断点了?
- 这样我拿线段树维护一下某点左边后几个被巴拉掉了
- 等等,咋不对啊。模拟一下,然后我发现做断点左边的点时要额外减去1...
最后,瞅了瞅题解。这个..别人都维护的是元素个数啊。。
做的还是有点小麻烦的。。。
code:
#include <cstdio>
#include <algorithm>
#define ls id<<1
#define rs id<<1|1
#define mid (l+r>>1)
#define R (t[id].r)
#define L (t[id].l)
#define Mid (L+R>>1)
using namespace std;
const int N=100010;
int a[N],di,n;
struct node2
{
int i,w;
bool friend operator <(node2 n1,node2 n2)
{
return n1.w>n2.w;
}
}b[N];
struct node
{
int l,r,w,lazy;
}t[N*4];
void build(int id,int l,int r)
{
L=l,R=r;
if(l==r) return;
build(ls,l,mid);
build(rs,mid+1,r);
}
void change(int id,int l,int r)
{
if(L==l&&R==r)
{
t[id].lazy-=1;
return;
}
t[id].w-=(r+1-l);
if(r<=Mid)
change(ls,l,r);
else if(l>Mid)
change(rs,l,r);
else
{
change(ls,l,Mid);
change(rs,Mid+1,r);
}
}
void push_down(int id)
{
t[id].w+=t[id].lazy*(R+1-L);
if(L!=R)
{
t[ls].lazy+=t[id].lazy;
t[rs].lazy+=t[id].lazy;
}
t[id].lazy=0;
}
int query(int id,int loc)
{
push_down(id);
if(L==R)
return t[id].w;
if(loc<=Mid)
return query(ls,loc);
else
return query(rs,loc);
}
long long ans=0;
int main()
{
int n1,n2;
scanf("%d%d",&n1,&n2);
for(int i=n1;i>=1;i--)
scanf("%d",a+i);
di=n1;n=n1+n2;
for(int i=1;i<=n2;i++)
scanf("%d",a+i+n1);
for(int i=1;i<=n;i++)
b[i].i=i,b[i].w=a[i];
sort(b+1,b+1+n);
build(1,1,n);
int now=b[1].i;
ans+=abs(now-di);
if(now>di) ans--;
di=now;
if(now!=n) change(1,now+1,n);
for(int i=2;i<=n;i++)
{
now=b[i].i;
int q1=query(1,now),q2=query(1,di);
ans+=abs(now+q1-di-q2);
if(now<di) ans--;
if(now!=n) change(1,now+1,n);
di=now;
}
printf("%lld\n",ans);
return 0;
}
2018.5.20
洛谷 P3253 [JLOI2013]删除物品 解题报告的更多相关文章
- 洛谷_Cx的故事_解题报告_第四题70
1.并查集求最小生成树 Code: #include <stdio.h> #include <stdlib.h> struct node { long x,y,c; ...
- 洛谷 P2317 [HNOI2005]星际贸易 解题报告
P2317 [HNOI2005]星际贸易 题目描述 输入输出格式 输入格式: 输出格式: 如果可以找到这样的方案,那么输出文件output.txt中包含两个整数X和Y.X表示贸易额,Y表示净利润并且两 ...
- 洛谷 P3802 小魔女帕琪 解题报告
P3802 小魔女帕琪 题目背景 从前有一个聪明的小魔女帕琪,兴趣是狩猎吸血鬼. 帕琪能熟练使用七种属性(金.木.水.火.土.日.月)的魔法,除了能使用这么多种属性魔法外,她还能将两种以上属性组合,从 ...
- 洛谷 P2606 [ZJOI2010]排列计数 解题报告
P2606 [ZJOI2010]排列计数 题目描述 称一个\(1,2,...,N\)的排列\(P_1,P_2...,P_n\)是\(Magic\)的,当且仅当对所以的\(2<=i<=N\) ...
- 洛谷1303 A*B Problem 解题报告
洛谷1303 A*B Problem 本题地址:http://www.luogu.org/problem/show?pid=1303 题目描述 求两数的积. 输入输出格式 输入格式: 两个数 输出格式 ...
- NOIP2015 D2T3 洛谷2680 BZOJ4326 运输计划 解题报告
前言:个人认为这是历年NOIP中比较简单的最后一题了,因此将自己的思路与大家分享. 题目大意: 给一棵无根树,给出m条路径.允许将树上的一条边的权值改为0.求m条路径长度最大值的最小值.n,m< ...
- 洛谷 P1110 [ZJOI2007]报表统计 解题报告
P1110 [ZJOI2007]报表统计 题目描述 \(Q\)的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小\(Q\)希望可以帮妈妈分担一些工作,作为她的生日礼物之一. 经过仔细 ...
- 洛谷 P2542 [AHOI2005]航线规划 解题报告
P2542 [AHOI2005]航线规划 题目描述 对Samuel星球的探险已经取得了非常巨大的成就,于是科学家们将目光投向了Samuel星球所在的星系--一个巨大的由千百万星球构成的Samuel星系 ...
- 洛谷 P3084 [USACO13OPEN]照片Photo 解题报告
[USACO13OPEN]照片Photo 题目描述 农夫约翰决定给站在一条线上的\(N(1 \le N \le 200,000)\)头奶牛制作一张全家福照片,\(N\)头奶牛编号\(1\)到\(N\) ...
随机推荐
- CF1153F Serval and Bonus Problem FFT
CF1153F Serval and Bonus Problem 官方的解法是\(O(n ^ 2)\)的,这里给出一个\(O(n \log n)\)的做法. 首先对于长度为\(l\)的线段,显然它的答 ...
- 蓝牙baseband概述
从蓝牙specispecification中看,基带协议主要分为8个部分来介绍的,分别是概述.物理信道.物理连接.逻辑传输.逻辑连接.封包.比特流的处理.组网行为.这里面会涉及到很多的概念,主要是在概 ...
- springboot @Value 获取计算机中绝对路径文件的内容
默认情况下使用 @Value("aaa.txt") private Resource txtResource; 这样获取到的是项目classpath 下的 aaa.txt 如果想获 ...
- 【下一代核心技术DevOps】:(七)持续集成Jenkins的应用(Aliyun Pipiline持续构建)
1. 前言 使用Jenkins比较好的就是可以在整个构建顺序中增加自定义的动作,比如构建成功给Leader发个邮件,给团队核心发个微信什么的. 当然最基本的核心还是它可以构建多种开发语言的项目,此类构 ...
- Jmeter(三十一)_数据驱动,业务关联
这种数据驱动的本质是:将测试的case,参数,url,预期结果,存储于本地excel中.运行脚本时,从文件中获取预期结果,将实际结果与预期结果比较,将实际结果,比较结果,响应状态码回写excel. 一 ...
- 【nodejs】让nodejs像后端mvc框架(asp.net mvc)一样处理请求--目录(8/8 完结)
为什么要做这个 在使用nodejs开发过程中,总是发现需要做很多重复性的体力劳动,且因为自身是服务端程序员出身,感觉有一些服务端好的东西其实可以在nodejs上得到应用并能提高一些开发工作效率. 本系 ...
- 基于 HTML5 Canvas 的 3D WebGL 机房创建
对于 3D 机房来说,监控已经不是什么难事,不同的人有不同的做法,今天试着用 HT 写了一个基于 HTML5 的机房,发现果然 HT 简单好用.本例是将灯光.雾化以及 eye 的最大最小距离等等功能在 ...
- Mvc_前后端绑定数据json集合
ViewBag.SysModuleList =new List<SysModule>(){.....}; var data = @Html.Raw(Json.Encode(ViewBag ...
- Cobbler自动化批量安装Linux操作系统 - 运维总结
一.Cobbler简述 Cobbler是一个自动化和简化系统安装的工具,通过使用网络引导来控制和启动安装.Cobbler的特性包括存储库镜像.Kickstart模板和连接电源管理系统.Cobbler通 ...
- Linux内核分析作业 NO.7
可执行程序的装载 于佳心 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 实 ...