bzoj1106

模拟+树状数组

先开始以为是先删距离最小的,这样可以减小上下的距离,然后觉得很难写,看码长很短,就看了题解,结果很奥妙

我们只考虑两种元素,就是如果像-a-b-a-b-这样的肯定得交换,如果像-a-b-b-a-或-a-a-b-b-这样的就不用交换,于是我们对于每个元素考虑其他元素,也就是统计两个相同元素中间有多少和这个元素构成区间相交,那么我们打个-1+1,然后树状数组统计一下就行了,然后每统计到右端点就把标记删除,相当于删除这种元素,一遇到右端点就直接交换删除,在树状数组里删除就可以了

#include<bits/stdc++.h>
using namespace std;
int n, top, ans;
int tree[100010], l[100010], r[100010], a[100010], mark[100010];
int lowbit(int i)
{
    return i & (-i);
}
void update(int pos, int delta)
{
    for(int i = pos; i <= 2 * n; i += lowbit(i)) tree[i] += delta;
}
int query(int pos)
{
    int ret = 0;
    for(int i = pos; i; i -= lowbit(i)) ret += tree[i];
    return ret;
}
int main()
{
    memset(l, 0x3f3f, sizeof(l));
    scanf("%d", &n);
    for(int i = 1; i <= 2 * n; ++i)
    {
        int x;
        scanf("%d", &a[i]);
        if(mark[a[i]]) update(i, -1);
        else update(i, 1);
        l[a[i]] = min(l[a[i]], i);
        r[a[i]] = max(r[a[i]], i);
        mark[a[i]] = 1;
    }
    for(int i = 1; i <= 2 * n; ++i) if(i == r[a[i]])
    {
        ans += query(i) - query(l[a[i]] - 1);
        update(l[a[i]], -1);
        update(r[a[i]], 1);
    }
    printf("%d\n", ans);
    return 0;
}

时间: 2024-09-30 10:14:30

bzoj1106的相关文章

bzoj1106 [POI2007]立方体大作战tet

Description 一个叫做立方体大作战的游戏风靡整个Byteotia.这个游戏的规则是相当复杂的,所以我们只介绍他的简单规则:给定玩家一个有2n个元素的栈,元素一个叠一个地放置.这些元素拥有n个不同的编号,每个编号正好有两个元素.玩家每次可以交换两个相邻的元素.如果在交换之后,两个相邻的元素编号相同,则将他们都从栈中移除,所有在他们上面的元素都会掉落下来并且可以导致连锁反应.玩家的目标是用最少的步数将方块全部消除. Input 输入文件第一行包含一个正整数n(1<=n<=50000).接

bzoj1106 树状数组

https://www.lydsy.com/JudgeOnline/problem.php?id=1106 一个叫做立方体大作战的游戏风靡整个Byteotia.这个游戏的规则是相当复杂的,所以我们只介绍他的简单规 则:给定玩家一个有2n个元素的栈,元素一个叠一个地放置.这些元素拥有n个不同的编号,每个编号正好有两个 元素.玩家每次可以交换两个相邻的元素.如果在交换之后,两个相邻的元素编号相同,则将他们都从栈中移除, 所有在他们上面的元素都会掉落下来并且可以导致连锁反应.玩家的目标是用最少的步数将

bzoj1106([POI2007]立方体大作战tet)(树状数组)

传送门 首先要看出,对于每一对,其凑到一起所需要的操作次数是中间没被匹配的个数. 于是想到贪心,每次操作所需次数最小的. 但其实做法并不需要这么麻烦,只用从左到右扫一遍. 如果当前数字已经出现过,就统计其中未匹配的个数,同时把这一对标记为“已匹配”,就不会对后面的答案造成影响. 用树状数组维护即可,第一次出现树状数组中对应位置的权值+1,第二次出现时,累计答案,同时把前面相同的数的位置树状数组里权值-1. #include<bits/stdc++.h> #define LL long long

poi2007

序:为什么写poi,zy说poi都是思路题目,不像hnoi妈的数据结构队..... 1.bzoj1102 题目大意:定义了一个山谷和山峰,求他们数量. 题解:这种题bfs咯,在bfs的时候记录一下相邻的比我大的有多少,比我小的有多少,然后更新答案: 代码: 1 #include<iostream> 2 #include<cstring> 3 #include<cstdio> 4 #include<algorithm> 5 #include<cmath&

[转载]hzwer的bzoj题单

counter: 664BZOJ1601 BZOJ1003 BZOJ1002 BZOJ1192 BZOJ1303 BZOJ1270 BZOJ3039 BZOJ1191 BZOJ1059 BZOJ1202 BZOJ1051 BZOJ1001 BZOJ1588 BZOJ1208 BZOJ1491 BZOJ1084 BZOJ1295 BZOJ3109 BZOJ1085 BZOJ1041 BZOJ1087 BZOJ3038 BZOJ1821 BZOJ1076 BZOJ2321 BZOJ1934 BZOJ