原题

给出一个n个数的数列ai ,对于第i个元素ai定义\(fi=min(|ai-aj|) (1<=j<i)\),f1=a1,求\(/sumfi\)


Splay板子题。

Splay讲解:http://www.cnblogs.com/mrsheep/p/8110483.html

//太懒了……

  1. #include<cstdio>
  2. #include<algorithm>
  3. #include<cmath>
  4. #define which(x) (ls[f[(x)]]==(x))
  5. #define N 33000
  6. using namespace std;
  7. int n,v,root,ls[N],rs[N],val[N],f[N],idx,ans;
  8. void Rotate(int u)
  9. {
  10. int v=f[u],w=f[v],b=which(u)?rs[u]:ls[u],dir=which(v);
  11. which(u)?(rs[u]=v,ls[v]=b):(ls[u]=v,rs[v]=b);
  12. f[v]=u;f[b]=v;f[u]=w;
  13. if (w) dir?ls[w]=u:rs[w]=u;
  14. }
  15. int read()
  16. {
  17. int ans=0,fu=1;
  18. char j=getchar();
  19. for (;j<'0' || j>'9';j=getchar()) if (j=='-') fu=-1;
  20. for (;j>='0' && j<='9';j=getchar()) ans*=10,ans+=j-'0';
  21. return ans*fu;
  22. }
  23. void splay(int x,int y)
  24. {
  25. while (f[x]!=y)
  26. {
  27. if (f[f[x]]!=y)
  28. {
  29. if (which(x)==which(f[x])) Rotate(f[x]);
  30. else Rotate(x);
  31. }
  32. Rotate(x);
  33. }
  34. if (!y) root=x;
  35. }
  36. void insert(int x)
  37. {
  38. int u=root,v=0;
  39. while (u)
  40. {
  41. v=u;
  42. if (x<val[u]) u=ls[u];
  43. else u=rs[u];
  44. }
  45. f[++idx]=v;
  46. val[idx]=x;
  47. if (v) x<val[v]?ls[v]=idx:rs[v]=idx;
  48. splay(idx,0);
  49. }
  50. int getmx(int x)
  51. {
  52. if (!x) return 97797977;
  53. while (rs[x]) x=rs[x];
  54. return val[x];
  55. }
  56. int getmn(int x)
  57. {
  58. if (!x) return 97797977;
  59. while (ls[x]) x=ls[x];
  60. return val[x];
  61. }
  62. int query()
  63. {
  64. int lmx=getmx(ls[root]),rmn=getmn(rs[root]);
  65. return min(abs(val[root]-lmx),abs(val[root]-rmn));
  66. }
  67. int main()
  68. {
  69. n=read();
  70. v=read();
  71. insert(v);
  72. ans+=v;
  73. for (int i=2;i<=n;i++)
  74. {
  75. v=read();
  76. insert(v);
  77. ans+=query();
  78. }
  79. printf("%d",ans);
  80. return 0;
  81. }

[bzoj] 1588 营业额统计 || Splay板子题的更多相关文章

  1. BZOJ 1588 营业额统计 Splay

    主要操作为Splay中插入节点,查找前驱和后继节点. 1: #include <cstdio> 2: #include <iostream> 3: #include <c ...

  2. BZOJ 1588 营业额统计

    Description 营业额统计 Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况. Tiger拿出了公司的账本,账本上记录了公司成立以来每 ...

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

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

  4. (HYSBZ)BZOJ 1588 营业额统计

    营业额统计 Time Limit: 5000MS   Memory Limit: 165888KB   64bit IO Format: %lld & %llu Description 营业额 ...

  5. BZOJ 1588 营业额统计 set

    题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1588 题目大意: 营业额统计 Tiger最近被公司升任为营业部经理,他上任后接受公司交 ...

  6. bzoj 1588营业额统计(HNOI 2002)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1588 splay  bottom-up的数组实现. 题意就是给你一组数,求每个数与在其前面且与其最相 ...

  7. 【BZOJ-1588】营业额统计 Splay

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

  8. Bzoj 1588: [HNOI2002]营业额统计(splay)

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec Memory Limit: 162 MB Description 营业额统计 Tiger最近被公司升任为营业部经理,他上 ...

  9. 1588: [HNOI2002]营业额统计 (splay tree)

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

随机推荐

  1. K8S全栈容器服务如何助力企业云化创新?

    容器编排管理平台Kubernetes在实践两年多后,市场主导地位被正式确定,随着首批认证服务商的宣布,围绕着容器的应用编排部署服务已然成熟,Kubernetes开始在商业场景为企业创造价值.华为云在K ...

  2. cf#516C. Oh Those Palindromes(最多回文子串的字符串排列方式,字典序)

    http://codeforces.com/contest/1064/problem/C 题意:给出一个字符串,要求重新排列这个字符串,是他的回文子串数量最多并输出这个字符串. 题解:字典序排列的字符 ...

  3. JMeter自学笔记3-创建自己的第一个测试用例

    一.写在前面的话: 上篇我们已经认识了JMeter的图形界面,大家应该都是很懵的.那么这篇,我们将学习使用JMeter创建第一个属于自己测试用例. 二.创建自己的第一个测试用例: 1.新建一个Thre ...

  4. Django - day00 第一个页面

    Django - day00 0.写在最前面 第一次接触Django,是在大三的做数据库课程设计的时候,当时好像还是1.8的版本,现转眼就到了2.0的版本. 当时由于没太多的课,仅花了不到一周的时间就 ...

  5. 交换学生 (Foreign Exchange,UVa10763)

    题目描述: 解题思路: 开一个数组,读入一次交换两个数,如果最后数组不变,即符合匹配 #include<iostream> #include<cstdio> #include& ...

  6. 代码对齐 (Alignment of Code,ACM/ICPC NEERC 2010,UVa1593)

    题目描述: 解题思路: 输入时提出单个字符串,并用一个数组记录每列最长长度,格式化输出 #include <iostream> #include <algorithm> #in ...

  7. 【Linux 运维】 Centos7.x 系统修复模式

    一.linux的运行级别: 运行级别就是来确定系统启动时到底启动那个服务. linux默认有7个运行级别: 0 关机 1 单用户模式,用于系统修复 2 不完全的命令模式,不含NFS服务 3 完全的命令 ...

  8. Paper Reading - CNN+CNN: Convolutional Decoders for Image Captioning

    Link of the Paper: https://arxiv.org/abs/1805.09019 Innovations: The authors propose a CNN + CNN fra ...

  9. HADOOP docker(九):hdfs权限

    1. 概述2. 用户身份标识3. 组映射4.关于权限的实现5.文件系统API的变更6.应用程序shell的变更7.超级用户8.ACLs9.ACL 文件系统API10.ACL命令11.参数配置12.总结 ...

  10. DFS中的奇偶剪枝(技巧)

    剪枝是什么,简单的说就是把不可行的一些情况剪掉,例如走迷宫时运用回溯法,遇到死胡同时回溯,造成程序运行时间长.剪枝的概念,其实就跟走迷宫避开死胡同差不多.若我们把搜索的过程看成是对一棵树的遍历,那么剪 ...