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. 【Qt】Qt5.12编译MySQl5.7驱动(亲自测试成功)

    目录 00. 目录 01. 安装Qt5.12 02. 打开MySQL源码项目 03. 编译MySQL驱动代码 04. 修改mysql.pro文件 05. 编译之后得到对应的库 06. 拷贝动态库到指定 ...

  2. ArcGIS JS之 applyEdits之后要素符号更新

    ArcGIS JS版本 ArcGIS JS 4.11 最近做一个地图服务,通过FeatureLayer.applyEdits()方法,更新唯一值的渲染字段,实现地图渲染根据用户的配置实时更新. 由于A ...

  3. EfCore基本用法

    db first 和 code first的基本使用方法 https://www.cnblogs.com/Starts_2000/p/mysql-efcore20-codefirst-dbfirst- ...

  4. wstngfw中配置freeradius

    wstngfw中配置freeradius Radius为各种网络设备和服务提供了一个认证来源. Radius认证常用于***.入网门户.交换机.路由器和防火墙.Radius认证比在网络上的不同设备跟踪 ...

  5. oracle 的分页、截断查询

    oracle 分页.截断查询 需求:从车管所的备案库中(oracle)取出数据,放到车综大数据平台(http方式) 现场情况:oracle中有三张表,CZRKXX(常住人口信息),ZDRYXX(重点人 ...

  6. Canvas 绘制一个像素风电子时钟

    想法是在 Canvas 上绘制由小方块组成的数字. 第一步是实现绘制小方块的方法,先画出一个边长为 5 的 10x10 个方块,使用两个 for 循环很简单就能完成. for (let i = 0; ...

  7. webpack4 + ejs 构建多页应用

    目录结构 ├─build webpack配置目录 │ ├─plugins.js │ ├─rules.js │ ├─transfromAssets.js //简单的一个插件,处理路径问题 │ └─web ...

  8. 2019最新Web前端经典面试试题(含答案)

    1,阐述清楚浮动的几种方式(常见问题)(1)父级div定义 height原理:父级div手动定义height,就解决了父级div无法自动获取到高度的问题. 优点:简单.代码少.容易掌握 缺点:只适合高 ...

  9. 发现一个对列排版挺好用的命令:column

    help [root@hdpool1 tmp]# column -h Usage: column [options] [file ...] Options: -c, --columns <wid ...

  10. Android NDK 学习之在C中调用Java的变量和静态变量

    本博客主要是在Ubuntu 下开发,且默认你已经安装了Eclipse,Android SDK, Android NDK, CDT插件. 在Eclipse中添加配置NDK,路径如下Eclipse-> ...