洛谷 P3253 [JLOI2013]删除物品 解题报告

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

原文地址:https://www.cnblogs.com/ppprseter/p/9064473.html

时间: 2024-10-09 21:35:04

洛谷 P3253 [JLOI2013]删除物品 解题报告的相关文章

洛谷OJ P1010 幂次方 解题报告

洛谷OJ P1010 幂次方 解题报告 by MedalPluS 题目描述   任何一个正整数都可以用2的幂次方表示.例如        137=2^7+2^3+2^0         同时约定方次用括号来表示,即a^b 可表示为a(b).由此可知,137可表示为:        2(7)+2(3)+2(0)进一步:7= 2^2+2+2^0   (21用2表示)        3=2+20   所以最后137可表示为:        2(2(2)+2+2(0))+2(2+2(0))+2(0)又如

洛谷OJ P1074 靶形数独 解题报告

洛谷OJ P1074 靶形数独 解题报告 by MedalPluS 题目描述  小城和小华都是热爱数学的好学生,最近,他们不约而同地迷上了数独游戏,好胜的他们想用数独来一比高低.但普通的数独对他们来说都过于简单了,于是他们向 Z 博士请教,Z 博士拿出了他最近发明的“靶形数独”,作为这两个孩子比试的题目. 靶形数独的方格同普通数独一样,在 9 格宽×9 格高的大九宫格中有 9 个 3 格宽×3 格高的小九宫格(用粗黑色线隔开的).在这个大九宫格中,有一些数字是已知的,根据这些数字,利用逻辑推理,

洛谷OJ P1141 01迷宫 解题报告

洛谷OJ P1141 01迷宫 解题报告 by MedalPluS [题目描述]    有一个仅由数字0与1组成的n×n格迷宫.若你位于一格0上,那么你可以移动到相邻4格中的某一格1上,同样若你位于一格1上,那么你可以移动到相邻4格中的某一格0上.你的任务是:对于给定的迷宫,询问从某一格开始能移动到多少个格子(包含自身).   [输入描述]   输入的第1行为两个正整数n,m.  下面n行,每行n个字符,字符只可能是0或者1,字符之间没有空格.  接下来m行,每行2个用空格分隔的正整数i,j,对

洛谷OJ P1433 吃奶酪 解题报告

洛谷OJ P1433 吃奶酪 解题报告 by MedalPluS 题目描述 房间里放着n块奶酪.一只小老鼠要把它们都吃掉,问至少要跑多少距离?老鼠一开始在(0,0)点处. 输入描述 第一行一个数n  (n<=15)接下来每行2个实数,表示第i块奶酪的坐标.两点之间的距离公式=sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2)) 输出描述 一个数,表示要跑的最少距离,保留2位小数. 分析 这题很明显就是一个搜索题,枚举一下1_n的全排列,然后从0开始,按照排列一个一个算,时间

洛谷1098 字符串的展开 解题报告

洛谷1098 字符串的展开 本题地址:http://www.luogu.org/problem/show?pid=1098 题目描述 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输出时,用连续递增的字母获数字串替代其中的减号,即,将上面两个子串分别输出为“defgh”和“45678”.在本题中,我们通过增加一些参数的设置,使字符串的展开更为灵活.具体约定如下:(1) 遇到下面的情

洛谷1125 笨小猴 解题报告

洛谷1125 笨小猴 本题地址:http://www.luogu.org/problem/show?pid=1125 题目描述 笨小猴的词汇量很小,所以每次做英语选择题的时候都很头疼.但是他找到了一种方法,经试验证明,用这种方法去选择选项的时候选对的几率非常大!这种方法的具体描述如下:假设maxn是单词中出现次数最多的字母的出现次数,minn是单词中出现次数最少的字母的出现次数,如果maxn-minn是一个质数,那么笨小猴就认为这是个Lucky Word,这样的单词很可能就是正确的答案. 输入输

洛谷P1162 填涂颜色 解题报告

by MedalPluS 题目描述: 由数字0 组成的方阵中,有一任意形状闭合圈,闭合圈由数字1构成,围圈时只走上下左右4个方向.现要求把闭合圈内的所有空间都填写成2.例如:6X6的方阵(n=6),涂色前和   涂色后的方阵如下:0 0 0 0 0 0      0 0 0 0 0 00 0 1 1 1 1      0 0 1 1 1 10 1 1 0 0 1      0 1 1 2 2 11 1 0 0 0 1      1 1 2 2 2 1 1 0 0 0 0 1      1 2 2

洛谷 P2469 [SDOI2010]星际竞速 解题报告

题目描述 10年一度的银河系赛车大赛又要开始了.作为全银河最盛大的活动之一,夺得这个项目的冠军无疑是很多人的梦想,来自杰森座α星的悠悠也是其中之一. 赛车大赛的赛场由N颗行星和M条双向星际航路构成,其中每颗行星都有一个不同的引力值.大赛要求车手们从一颗与这N颗行星之间没有任何航路的天体出发,访问这N颗行星每颗恰好一次,首先完成这一目标的人获得胜利. 由于赛制非常开放,很多人驾驶着千奇百怪的自制赛车来参赛.这次悠悠驾驶的赛车名为超能电驴,这是一部凝聚了全银河最尖端科技结晶的梦幻赛车.作为最高科技的

洛谷 P2466 Sue的小球 解题报告

P2466 [SDOI2008]Sue的小球 题目描述 Sue和Sandy最近迷上了一个电脑游戏,这个游戏的故事发在美丽神秘并且充满刺激的大海上,Sue有一支轻便小巧的小船.然而,Sue的目标并不是当一个海盗,而是要收集空中漂浮的彩蛋,Sue有一个秘密武器,只要她将小船划到一个彩蛋的正下方,然后使用秘密武器便可以在瞬间收集到这个彩蛋.然而,彩蛋有一个魅力值,这个魅力值会随着彩蛋在空中降落的时间而降低,Sue要想得到更多的分数,必须尽量在魅力值高的时候收集这个彩蛋,而如果一个彩蛋掉入海中,它的魅力