#424 Div2 E

题意

给出一个 n 个数的数列,从前往后取数,如果第一个数是当前数列的最小值,则取出,否则将它放到数列尾端,问使数列为空需要多少步操作。

分析

用数据结构去模拟。

线段树维护区间最小值及取得最小值的位置。树状数组维护仍存在的数的个数( 1 表示未取,0 表示已取)。

首先寻找全局最小值,那么答案加上它前面的存在的数的个数,然后删掉这个值,(在线段树中将这个值置为无穷大等价于删除掉它)。

设这个前面删掉的最小值位置为 idx,那么再从 idx+1 往后找,是否存在全局最小值。

如果存在下标为 pos ,那么答案加上区间 (idx, pos] 仍然存在的数的个数(使用树状数组计算),再把 idx 置为 pos。

如果不存在,答案加上 (idx, n] 仍然存在的数的个数,退出当前循环,从头开始找(即把 idx 置为 0)。

code

#include<bits/stdc++.h>
#define lson l, m, rt * 2
#define rson m + 1, r, rt * 2 + 1
using namespace std;
typedef long long ll;
const int MAXN = 1e5 + 5;
const int INF = 2e9 + 1;
int a[MAXN];
struct BIT {
int f[MAXN];
void add(int p, int c) {
while(p <= MAXN) {
f[p] += c;
p += (p & -p);
}
}
int query(int p) {
int s = 0;
while(p) {
s += f[p];
p -= (p & -p);
}
return s;
}
} bit;
struct ST {
struct node {
int id, val;
node() {}
node(int id_, int val_):id(id_), val(val_) {}
} ary[MAXN << 2];
node pushUp(node& nd, int rt) {
if(ary[2 * rt].val <= ary[2 * rt + 1].val) {
nd.id = ary[2 * rt].id;
nd.val = ary[2 * rt].val;
} else {
nd.id = ary[2 * rt + 1].id;
nd.val = ary[2 * rt + 1].val;
}
}
void build(int l, int r, int rt) {
if(l == r) {
ary[rt].id = l;
ary[rt].val = a[l];
return;
}
int m = (l + r) / 2;
build(lson);
build(rson);
pushUp(ary[rt], rt);
}
void query(int L, int R, int& pos, int& res, int l, int r, int rt) {
if(L <= l && R >= r) {
if(ary[rt].val < res) {
res = ary[rt].val;
pos = ary[rt].id;
}
return;
}
int m = (l + r) / 2;
if(L <= m) query(L, R, pos, res, lson);
if(R > m) query(L, R, pos, res, rson);
}
void update(int p, int val, int l, int r, int rt) {
if(l == r) {
ary[rt].val = val;
return;
}
int m = (l + r) / 2;
if(m < p) update(p, val, rson);
else update(p, val, lson);
pushUp(ary[rt], rt);
}
} st;
int main() {
int n;
cin >> n;
for(int i = 1; i <= n; i++) {
cin >> a[i];
bit.add(i, 1);
}
st.build(1, n, 1);
ll ans = 0;
for(int T = 0; T < n;) {
for(int idx = 0; idx < n && T < n;) {
int minV = INF, minv = INF, posV, posv;
st.query(1, n, posV, minV, 1, n, 1);
st.query(idx + 1, n, posv, minv, 1, n, 1);
if(minv != minV) {
ans += bit.query(n) - bit.query(idx);
break;
}
ans += bit.query(posv) - bit.query(idx);
st.update(posv, INF, 1, n, 1);
bit.add(posv, -1);
T++;
idx = posv;
}
}
cout << ans << endl;
return 0;
}

#424 Div2 E的更多相关文章

  1. #424 Div2 C

    #424 Div2 C 题意 给出 k 个分数,初始分数未知,按顺序把这 k 个分数加到初始分数上,已知 n 个加入分数后的结果(无序),问初始分数有多少种可能. 分析 也就是说这 n 个结果,它们之 ...

  2. Codeforces Round #424 Div2 E. Cards Sorting

    我只能说真的看不懂题解的做法 我的做法就是线段树维护,毕竟每个数的顺序不变嘛 那么单点维护 区间剩余卡片和最小值 每次知道最小值之后,怎么知道需要修改的位置呢 直接从每种数维护的set找到现在需要修改 ...

  3. codeforces round #424 div2

    A 暴力查询,分三段查就可以了 #include<bits/stdc++.h> using namespace std; ; int n, pos; int a[N]; int main( ...

  4. #424 Div2 Problem C Jury Marks (二分 && 暴力 && std::unique && 思维)

    题目链接 :http://codeforces.com/contest/831/problem/C 题意 :选手有一个初始积分,接下来有k个裁判为他加分或减分(时间顺序给出),然后告诉你n(1< ...

  5. bc#54 div2

    用小号做的div2 A:竟然看错了排序顺序...白白WA了两发 注意读入一整行(包括空格):getline(cin,st) [gets也是资瓷的 #include<iostream> us ...

  6. $('div a') 与$('div>a'),.div+.div2与.div~.div2

    $('div a'):div标签下所有层次a元素的jquery对象 $('div>a'):div标签下子元素层次a元素的jquery对象 <body> <div class=' ...

  7. SRM 657 DIV2

    -------一直想打SRM,但是感觉Topcoder用起来太麻烦了.题目还是英文,不过没什么事干还是来打一打好了.但是刚注册的号只能打DIV2,反正我这么弱也只适合DIV2了.. T1: 题目大意: ...

  8. CodeForces Round 192 Div2

    This is the first time I took part in Codeforces Competition.The only felt is that my IQ was contemp ...

  9. Codeforce Round #211 Div2

    真的是b到不行啊! 尼玛C题一个这么简单的题目没出 aabbccddee 正确的是aabccdee 我的是   aabcdee 硬是TM的不够用,想半天还以为自己的是对的... A:题... B:题. ...

随机推荐

  1. python学习笔记六:内置函数

    一.数学相关 1.绝对值:abs(-1) 2.最大最小值:max([1,2,3]).min([1,2,3]) 3.序列长度:len('abc').len([1,2,3]).len((1,2,3)) 4 ...

  2. jmeter 运行脚本报错 java.net.BindException: Address already in use

    在win下跑jmeter时,在聚合报告中出现错误.打开日志文件(前提是将日志写入了指定文件) 发现报错的原因为:java.net.BindException: Address already in u ...

  3. 【转载】Unity3D研究院之静态自动检查代码缺陷与隐患

    代码缺陷和代码错误的最大区别是,代码缺陷不影响游戏编译,而代码错误编译都不通过.但是代码缺陷会影响游戏发布后产生的一系列BUG..我今天无意间逛外国论坛发现的一个方法,使用了一下感觉挺给力的第一时间分 ...

  4. hadoop-搭建(转)--亲测好用 (一)

    1)JDK软件 下载地址:http://www.oracle.com/technetwork/java/javase/index.html 2)Hadoop软件 下载地址:http://hadoop. ...

  5. springboot集成shiro——使用RequiresPermissions注解无效

    在Springboot环境中继承Shiro时,使用注解@RequiresPermissions时无效 @RequestMapping("add") @RequiresPermiss ...

  6. XML快速入门

    XML是什么 Extensible Markup Language 自定义标签: 用来传输数据: 可扩展标记语言,是一种类似超文本标记语言的标记语言. 与HTML的比较: 1.不是用来替代HTML的: ...

  7. Error: could not find java.dll 解决办法

    Error: could not find java.dll 问题: 安装配置Java环境变量后,在命令行中运行java -version进行测试时却出现下面的问题: Error: opening r ...

  8. P4113 [HEOI2012]采花

    题目描述 萧薰儿是古国的公主,平时的一大爱好是采花. 今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花. 花园足够大,容纳了n朵花,花有c种颜色(用整数1-c表示),且花是排成一排的,以便于 ...

  9. C++11 tuple元组

    C++11 tuple 元组 tuple容器(元组), 是表示元组容器, 是不包含任何结构的,快速而低质(粗制滥造, quick and dirty)的, 可以用于函数返回多个返回值; tuple容器 ...

  10. h5 Visibility API总结

    最近活动中的小游戏,有涉及页面隐藏或app后台运行时候,暂停游戏的功能,使用了h5的Visibility API,在此总结如下: 两个属性 document.hidden (Read only) 如果 ...