https://www.luogu.org/problemnew/show/2234

将权值离散化,以权值为下标建立权值线段树

#include <bits/stdc++.h>

using namespace std;
const int N = ;
const int oo = ; #define gc getchar()
#define lson jd << 1
#define rson jd << 1 | 1 struct Node_1 {int data, id;} A[N];
struct Node_2 {int l, r, w, Max, Min;} T[N << ];
int Ask[N], n, Answer, D[N], before, after; inline int read(){
int x = , f = ; char c = gc;
while(c < '' || c > '') {if(c == '-') f = -; c = gc;}
while(c >= '' && c <= '') x = x * + c - '', c = gc;
return x * f;
} bool cmp(Node_1 a, Node_1 b) {return a.data < b.data;} void pushup(int jd){
T[jd].w = T[lson].w + T[rson].w;
T[jd].Max = max(T[lson].Max, T[rson].Max);
T[jd].Min = min(T[lson].Min, T[rson].Min);
} void build_tree(int l, int r, int jd){
T[jd].l = l; T[jd].r = r; T[jd].Min = oo - ; T[jd].Max = -;
if(l == r) return ;
int mid = (l + r) >> ;
build_tree(l, mid, lson);
build_tree(mid + , r, rson);
} void Poi_G(int l, int r, int jd, int x){
if(l == r) {T[jd].w = ; T[jd].Max = l; T[jd].Min = l; return ;}
int mid = (l + r) >> ;
if(x <= mid) Poi_G(l, mid, lson, x);
else Poi_G(mid + , r, rson, x);
pushup(jd);
} void Sec_Min(int l, int r, int jd, int x, int y){
if(!T[jd].w) return ;
if(x <= l && r <= y) {after = min(after, T[jd].Min); return ;}
int mid = (l + r) >> ;
if(x <= mid) Sec_Min(l, mid, lson, x, y);
if(y > mid) Sec_Min(mid + , r, rson, x, y);
} void Sec_Max(int l, int r, int jd, int x, int y){
if(!T[jd].w) return ;
if(x <= l && r <= y)
{before = max(before, T[jd].Max); return ;}
int mid = (l + r) >> ;
if(x <= mid) Sec_Max(l, mid, lson, x, y);
if(y > mid) Sec_Max(mid + , r, rson, x, y);
} int main()
{
n = read();
for(int i = ; i <= n; i ++) {A[i].data = read(); A[i].id = i;}
sort(A + , A + n + , cmp);//按照权值进行排序
Ask[A[].id] = ; D[] = A[].data; int Id = ;//第i次访问的那个点在线段树中的位置
for(int i = ; i <= n; i ++){
if(A[i].data == A[i - ].data) continue ;
Ask[A[i].id] = Id; D[Id] = A[i].data;//线段树中位置对应的点的权值
Id ++;
}
Id --;
build_tree(, Id, );//建树
Answer += D[Ask[]];//第1次访问的点在线段树中的位置所对应的权值
Poi_G(, Id, , Ask[]);
for(int i = ; i <= n; i ++){
if(!Ask[i]) continue ;
before = - oo, after = oo;
Sec_Max(, Id, , , Ask[i]);
Sec_Min(, Id, , Ask[i] + , Id);
if(before == - oo) Answer += D[after] - D[Ask[i]];
else if(after == oo) Answer += D[Ask[i]] - D[before];
else Answer += min(abs(D[Ask[i]] - D[before]), abs(D[Ask[i]] - D[after]));
Poi_G(, Id, , Ask[i]);
}
cout << Answer;
return ;
}

[HNOI2002]营业额统计 II的更多相关文章

  1. BZOJ1588: [HNOI2002]营业额统计[BST]

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 14151  Solved: 5366[Submit][Sta ...

  2. BZOJ 1588: [HNOI2002]营业额统计

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 14396  Solved: 5521[Submit][Sta ...

  3. BZOJ 1588: [HNOI2002]营业额统计 双向链表 / splay / treap

    1588: [HNOI2002]营业额统计 Description 营业额统计 Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况. Tiger ...

  4. BZOJ1588 HNOI2002 营业额统计 [Splay入门题]

    [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 4128  Solved: 1305 Description 营业额统计 ...

  5. bzoj 1588: [HNOI2002]营业额统计 treap

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 13902  Solved: 5225[Submit][Sta ...

  6. 数据结构:(平衡树,链表)BZOJ 1588[HNOI2002]营业额统计

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 12173  Solved: 4354[Submit][Sta ...

  7. bzoj1588 [HNOI2002]营业额统计(Treap)

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 11485  Solved: 4062[Submit][Sta ...

  8. 1588: [HNOI2002]营业额统计

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 9203  Solved: 3097[Submit][Stat ...

  9. 【链表】BZOJ1588: [HNOI2002]营业额统计

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 17555  Solved: 7179[Submit][Sta ...

随机推荐

  1. VMware虚拟机(Ubuntu)通过主机代理实现——浏览器+终端访问外网

    环境说明:主机win10 + 虚拟机ubunut16.04 + 主机s-h-a-d-o-w-socks win10 主机相关操作配置1: 按下 Win + R 快捷键,输入 cmd ,然后在命令行中输 ...

  2. PB之常用函数

    原文网址:https://www.cnblogs.com/zhaoxiong/p/8082523.html PB之常用函数 弹出窗口:messagebox() 基本写法:Messagebox('标题' ...

  3. AtomicIntegerFieldUpdater和AtomicInteger

    为什么有了AtomicInteger还需要AtomicIntegerFieldUpdater? 当需要进行原子限定的属性所属的类会被创建大量的实例对象, 如果用AtomicInteger, 每个实例里 ...

  4. javascript之typeof

    定义和用法

  5. Python之原始数据-1

    一.数据对于模型来说是基础,是数据成就了模型,而现在的又是一个数据时代,比如:淘宝等.通过对用户数据的分析挖掘,预测用户的消费习惯等,再比如:人工智能.通过提取摄像头的图片帧数,通过分析图片,得出具体 ...

  6. Flask无法访问(127.0.0.1:5000)的问题解决方法

    Flask默认开启的ip地址是:http://127.0.0.1:5000/ 但在运行时可能存在无法访问的问题,特别是当我们在linux服务器上搭建flask时,此时需要将代码修改如下: app.ru ...

  7. centos+docker+jenkins

    1.直接运行jenkins镜像,无该镜像会直接下载 docker run -p 8080:8080 -p 50000:50000 -d -v /home/jenkins-home-docker:/va ...

  8. Elasticsearch 入门,基本概念和操作

    基本概念 Node 与 Cluster Elastic 本质上是一个分布式数据库,允许多台服务器协同工作,每台服务器可以运行多个 Elastic 实例. 单个 Elastic 实例称为一个节点(nod ...

  9. 【异常】jps6432 -- process information unavailable

    1 现象

  10. 【OF框架】搭建标准工作环境

    前言 统一工作环境,统一工具集,是沟通效率的基础.如同语言一样,使用不同语言的人,需要花更多的精力去理解语言,然后才是理解语言的内容,而使用相同语言的人,对话过程直接进入到内容.对于语言不统一增加的效 ...