P3253 [JLOI2013]删除物品

题目描述

箱子再分配问题需要解决如下问题:

(1)一共有\(N\)个物品,堆成\(M\)堆。

(2)所有物品都是一样的,但是它们有不同的优先级。

(3)你只能够移动某堆中位于顶端的物品。

(4)你可以把任意一堆中位于顶端的物品移动到其它某堆的顶端。若此物品是当前所有物品中优先级最高的,可以直接将之删除而不用移动。

(5)求出将所有物品删除所需的最小步数。删除操作不计入步数之中。

(6)只是一个比较难解决的问题,这里你只需要解决一个比较简单的版本: 不会有两个物品有着相同的优先级,且\(M=2\)

输入输出格式

输入格式:

第一行是包含两个整数\(N1,N2\)分别表示两堆物品的个数。接下来有\(N1\)行整数按照从顶到底的顺序分别给出了第一堆物品中的优先级,数字越大,优先级越高。再接下来的N2行按照同样的格式给出了第二堆物品的优先级。

输出格式:

对于每个数据,请输出一个整数,即最小移动步数。

说明

\(1<=N1+N2<=100000\)


说一下我做这个题的心路历程。

  1. 汉诺\(n\)塔问题?
  2. 两个栈?
  3. 等等,我似不似看错了,这不就是个模拟???
  4. 好像没错啊...
  5. 噫?模拟是\(O(n^2)\)?
  6. 苟不住了估计要跑数据结构
  7. 噫,我把这一坨挪到另一个上面后它们距离当前栈顶的距离是翻转区间???
  8. 分......分块?完了不会分块啊
  9. 瞎画+摸鱼\(ing\)
  10. 等等,我把两个栈bu~成一个数组后不仅只用挪中间的断点了
  11. 这样我拿线段树维护一下某点左边后几个被巴拉掉了
  12. 等等,咋不对啊。模拟一下,然后我发现做断点左边的点时要额外减去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]删除物品 解题报告的更多相关文章

  1. 洛谷_Cx的故事_解题报告_第四题70

    1.并查集求最小生成树 Code: #include <stdio.h> #include <stdlib.h>   struct node {     long x,y,c; ...

  2. 洛谷 P2317 [HNOI2005]星际贸易 解题报告

    P2317 [HNOI2005]星际贸易 题目描述 输入输出格式 输入格式: 输出格式: 如果可以找到这样的方案,那么输出文件output.txt中包含两个整数X和Y.X表示贸易额,Y表示净利润并且两 ...

  3. 洛谷 P3802 小魔女帕琪 解题报告

    P3802 小魔女帕琪 题目背景 从前有一个聪明的小魔女帕琪,兴趣是狩猎吸血鬼. 帕琪能熟练使用七种属性(金.木.水.火.土.日.月)的魔法,除了能使用这么多种属性魔法外,她还能将两种以上属性组合,从 ...

  4. 洛谷 P2606 [ZJOI2010]排列计数 解题报告

    P2606 [ZJOI2010]排列计数 题目描述 称一个\(1,2,...,N\)的排列\(P_1,P_2...,P_n\)是\(Magic\)的,当且仅当对所以的\(2<=i<=N\) ...

  5. 洛谷1303 A*B Problem 解题报告

    洛谷1303 A*B Problem 本题地址:http://www.luogu.org/problem/show?pid=1303 题目描述 求两数的积. 输入输出格式 输入格式: 两个数 输出格式 ...

  6. NOIP2015 D2T3 洛谷2680 BZOJ4326 运输计划 解题报告

    前言:个人认为这是历年NOIP中比较简单的最后一题了,因此将自己的思路与大家分享. 题目大意: 给一棵无根树,给出m条路径.允许将树上的一条边的权值改为0.求m条路径长度最大值的最小值.n,m< ...

  7. 洛谷 P1110 [ZJOI2007]报表统计 解题报告

    P1110 [ZJOI2007]报表统计 题目描述 \(Q\)的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小\(Q\)希望可以帮妈妈分担一些工作,作为她的生日礼物之一. 经过仔细 ...

  8. 洛谷 P2542 [AHOI2005]航线规划 解题报告

    P2542 [AHOI2005]航线规划 题目描述 对Samuel星球的探险已经取得了非常巨大的成就,于是科学家们将目光投向了Samuel星球所在的星系--一个巨大的由千百万星球构成的Samuel星系 ...

  9. 洛谷 P3084 [USACO13OPEN]照片Photo 解题报告

    [USACO13OPEN]照片Photo 题目描述 农夫约翰决定给站在一条线上的\(N(1 \le N \le 200,000)\)头奶牛制作一张全家福照片,\(N\)头奶牛编号\(1\)到\(N\) ...

随机推荐

  1. [转]curl的错误代码

    转贴者按: 今天在使用curl的时候碰到了一个错误,如下所示: External Program Failed: D:\Tools\curl\curl.exe (return code was 18) ...

  2. B. Heaters Div3

    链接 [http://codeforces.com/contest/1066/problem/B] 分析 具体看代码,贪就完事了 代码 #include<bits/stdc++.h> us ...

  3. 个人作业Week2-代码复审(修改明确了要求)

    代码复审 零,说在前面的话 大家完成了个人项目之后,都写了很多代码. 这些代码可能: 大括号换行/不换行 使用tab缩进/使用空格缩进 变量名函数名的定义很好/不好 每个函数都有详细的注释解释函数的功 ...

  4. 2-Twenty Second Scrum Meeting-20151222

    任务安排 成员 今日完成 明日任务 闫昊 服务器关闭,开发停滞……  …… 唐彬 服务器关闭,开发停滞……  …… 史烨轩  服务器关闭,开发停滞……  …… 余帆   路径保存 路径整合 金哉仁   ...

  5. Linux期末总结

    Linux内核学习总结 1.计算机是如何工作的? 存储程序计算机工作模型 X86汇编基础 汇编一个简单的C程序分析其汇编指令执行过程 2.操作系统是如何工作的? 三个法宝——存储程序计算机.函数调用堆 ...

  6. 第三个Sprint冲刺总结

    第三个Sprint冲刺总结 1.燃尽图 2.本阶段总结: 本阶段主要是对产品进行完善和美化,所以工作量不是很多.但要做精,做好并非是一件简单的事情.我们各组员都安排了各自的任务,如参考各行业的优秀ap ...

  7. 3-Python3从入门到实战—基础之数据类型(数字-Number)

    Python从入门到实战系列--目录 Python3 中有六个标准的数据类型: Number(数字) String(字符串) List(列表) Tuple(元组) Sets(集合) Dictionar ...

  8. Notepad++找回Plugin Manager{在v7.50后(包括7.50)不带有插件管理器(Plugin Manager)}

    https://github.com/notepad-plus-plus/notepad-plus-plus/issues/2459 64 bit Plugin Manager is now avai ...

  9. Java代码安全

    https://www.owasp.org/index.php/Category:Java

  10. HTTP Client使用总结

    1.如果服务器使用HTTPS协议,使用HTTPClient的话,需要配以EasySSLProtocolSocketFactory 2.Tomcat对HTTP的Post和Get请求处理是不一样的.Spr ...