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. S04_CH03_QSPI烧写LINUX系统

    S04_CH03_QSPI烧写LINUX系统 3.1概述 3.2搭建硬件系统 本章硬件工程还是使用<S04_CH01_搭建工程移植LINUX/测试EMMC/VGA>所搭建的VIVADO工程 ...

  2. AS3动画效果常用公式

    缓动公式: sprite.x += (targetX – sprite.x) * easing;//easing为缓动系数变量 sprite.y += (targetY – sprite.y) * e ...

  3. 关于window.location.hash的理解及其应用(转)

    原文1:https://blog.csdn.net/zhuchuji/article/details/50736360 原文2(window.location.href和window.location ...

  4. git版本控制系统重新认识

    git 版本控制系统 目标:完全搞懂git分布式版本控制系统 搭建git版本控制系统 cvs集中化版本控制系统--集中式管理的服务器 git分布式版本控制系统--会将原始代码仓库镜像下来 新项目使用g ...

  5. 【SoloPi】SoloPi使用4-功能使用,一机多控

    Soloπ是什么Soloπ是一个无线化.非侵入式的Android自动化工具,公测版拥有录制回放.性能测试.一机多控三项主要功能,能为测试开发人员节省宝贵时间. 一机多控功能Soloπ支持通过操作一台主 ...

  6. github新建远程仓库初始化记录

    …or create a new repository on the command line echo "# 输出内容" >> README.md git init ...

  7. Ext之页面多次请求问题(下拉框发送无关请求)

    extjs 下拉框在拉取本地数据,然后又要展示后台数据时,出现过此问题(加载页面,自动发送无关的请求导致后台出现错误日志) { xtype:'combo', id:'state', width:130 ...

  8. Java 之 IO流概述

    一.IO 流 我们知道存在硬盘中数据是永久保存的,而在内存中的数据只是临时的,内存中的数据可以存入硬盘中,硬盘中的数据也也可以读入内存中. 我们把这种数据的传输,可以看做一种数据的流动,按照流动的方法 ...

  9. pygame安装遇到的坑

    坑一:python版本冲突,电脑同时安装多个版本的python,由于每个都是python.exe,cmd命令窗口输入的python不一定是你想要的版本,所以最好还是安装单个版本即可. 坑二:由于电脑安 ...

  10. 布隆过滤算法体会(BlooomFilter)

    在一个m位的位数组里,一个字符串经过k次hash随机分布到k个位置. http://www.cnblogs.com/aspnethot/articles/3442813.html 布隆filter数据 ...