当前位置: 首页 > 编程日记 > 正文

bzoj 4695: 最假女选手

……一道丧病线段树膜板题……

被常数卡的死去活来……QAQ

学到了些奇技淫巧:把取min标记 和 区间最小值 合并

可以快很多……

#include <bits/stdc++.h>
#define lc(t) ((t) << 1)
#define rc(t) (((t) << 1) | 1)
#define N 2000010
#define INF 1000000000
#define LL long longtemplate <class T> inline T &read(T &x)
{static int f;static char c; for (f = 1; !isdigit(c = getchar()); ) {if (c == '-')f = -1;}for (x = 0; isdigit(c); c = getchar()) {x = x * 10 + c - 48;}return x *= f;
}template <class T> inline void write(T x, const char p = '\n')
{static int top;static int s[30];if (x < 0) {x = -x;putchar('-');}do s[++ top] = x % 10 + 48;while (x /= 10);while (top)putchar(s[top --]);putchar(p);
}using namespace std;
int n, m;
int mn[N], mx[N], cn[N], cx[N], sn[N], sx[N]; LL sum[N];
int t_a[N], t_n[N], t_x[N], i_n[N], i_x[N];
int lb[N], rb[N];
inline void upd(register int t)
{sum[t] = sum[lc(t)] + sum[rc(t)];if (mn[lc(t)] == mn[rc(t)]) mn[t] = mn[lc(t)], cn[t] = cn[lc(t)] + cn[rc(t)], sn[t] = min(sn[lc(t)], sn[rc(t)]);else if (mn[lc(t)] < mn[rc(t)]) mn[t] = mn[lc(t)], cn[t] = cn[lc(t)], sn[t] = min(sn[lc(t)], mn[rc(t)]);else mn[t] = mn[rc(t)], cn[t] = cn[rc(t)], sn[t] = min(mn[lc(t)], sn[rc(t)]);if (mx[lc(t)] == mx[rc(t)]) mx[t] = mx[lc(t)], cx[t] = cx[lc(t)] + cx[rc(t)], sx[t] = max(sx[lc(t)], sx[rc(t)]);else if (mx[lc(t)] > mx[rc(t)]) mx[t] = mx[lc(t)], cx[t] = cx[lc(t)], sx[t] = max(sx[lc(t)], mx[rc(t)]);else mx[t] = mx[rc(t)], cx[t] = cx[rc(t)], sx[t] = max(mx[lc(t)], sx[rc(t)]);}
void build(int t, int l, int r)
{lb[t] = l; rb[t] = r;if (l == r) {int x;read(x);mn[t] = mx[t] = sum[t] = x; cn[t] = cx[t] = 1; sn[t] = INF; sx[t] = -INF;}else {build(lc(t), l, (l + r) / 2);build(rc(t), (l + r) / 2 + 1, r);upd(t);}
}
inline void add(register int t, int d)
{sum[t] += (LL)d * (rb[t] - lb[t] + 1);mn[t] += d; mx[t] += d; sn[t] += d; sx[t] += d;t_a[t] += d;
}template <class T> inline void chkmin(T &x, T y) { x > y && (x = y); }
template <class T> inline void chkmax(T &x, T y) { x < y && (x = y); }
inline void m_x(register int t, int d)
{sum[t] += (LL)cn[t] * (d - mn[t]);mn[t] = d; chkmax(mx[t], d);if (mx[t] == mn[t]){cx[t] = cn[t] = rb[t] - lb[t] + 1;sum[t] = (LL)mx[t] * (rb[t] - lb[t] + 1);sn[t] = INF; sx[t] = -INF;}else chkmax(sx[t], d);
}
inline void m_n(register int t, int d)
{sum[t] += (LL)cx[t] * (d - mx[t]);mx[t] = d; chkmin(mn[t], d);if (mx[t] == mn[t]){cx[t] = cn[t] = rb[t] - lb[t] + 1;sum[t] = (LL)mx[t] * (rb[t] - lb[t] + 1);sn[t] = INF; sx[t] = -INF;}else chkmin(sn[t], d);
}
inline void psdw(register int t)
{if (t_a[t]){add(lc(t), t_a[t]);add(rc(t), t_a[t]);t_a[t] = 0;}if (mx[lc(t)] > mx[t] && sx[lc(t)] < mx[t]) m_n(lc(t), mx[t]);if (mx[rc(t)] > mx[t] && sx[rc(t)] < mx[t]) m_n(rc(t), mx[t]);if (mn[lc(t)] < mn[t] && sn[lc(t)] > mn[t]) m_x(lc(t), mn[t]);if (mn[rc(t)] < mn[t] && sn[rc(t)] > mn[t]) m_x(rc(t), mn[t]);
}
namespace segment
{int l, r, d;void seg_add(int t){if (l <= lb[t] && rb[t] <= r){add(t, d);return;}psdw(t);if (l <= rb[lc(t)]) seg_add(lc(t));if (r >= lb[rc(t)]) seg_add(rc(t));upd(t);}void seg_m_x(int t){if (mn[t] >= d) return;if (l <= lb[t] && rb[t] <= r && sn[t] > d){m_x(t, d);return;}psdw(t);if (l <= rb[lc(t)]) seg_m_x(lc(t));if (r >= lb[rc(t)]) seg_m_x(rc(t));upd(t);}void seg_m_n(int t){if (mx[t] <= d) return;if (l <= lb[t] && rb[t] <= r && sx[t] < d){m_n(t, d);return;}psdw(t);if (l <= rb[lc(t)]) seg_m_n(lc(t));if (r >= lb[rc(t)]) seg_m_n(rc(t));upd(t);}LL get_sum(int t){if (l <= lb[t] && rb[t] <= r){return sum[t];}LL d = 0;psdw(t);if (l <= rb[lc(t)]) d += get_sum(lc(t));if (r >= lb[rc(t)]) d += get_sum(rc(t));return d;}int get_max(int t){if (l <= lb[t] && rb[t] <= r){return mx[t];}int d = -INF;psdw(t);if (l <= rb[lc(t)]) d = max(d, get_max(lc(t)));if (r >= lb[rc(t)]) d = max(d, get_max(rc(t)));return d;}int get_min(int t){if (l <= lb[t] && rb[t] <= r){return mn[t];}int d = INF;psdw(t);if (l <= rb[lc(t)]) d = min(d, get_min(lc(t)));if (r >= lb[rc(t)]) d = min(d, get_min(rc(t)));return d;}
}int main()
{read(n);build(1, 1, n);read(m);while (m --){using namespace segment;int opt;read(opt); read(l); read(r);if (opt <= 3) read(d);switch (opt){case 1: seg_add(1); break;case 2: seg_m_x(1); break;case 3: seg_m_n(1); break;case 4: write(get_sum(1)); break;case 5: write(get_max(1)); break;case 6: write(get_min(1)); break;}}//write(c, ' '); write(d);
}

转载于:https://www.cnblogs.com/AwD-/p/6243103.html

相关文章:

python 打包 .app 运行 控制台窗口_Python打包工具

1 Python打包工具目前在windows平台上将Python程序打包成exe文件主要有三个工具。今天将一个Tkinter写的界面程序打包成exe文件&#xff0c;三个工具都试了一遍&#xff0c;感觉PyInstaller会比较好用一些。2 py2exe2.1 下载安装2.2 启动脚本写一个setup_py2exe.py文件from dis…

地址池命令 思科理由_思科互联网络操作系统 ——路由器接口

点击蓝字关注我们路由器接口接口配置是最重要的路由器配置之一&#xff0c;因为若没有接口,路由器几乎就毫无用处。另外&#xff0c;要与其他设备通信&#xff0c;接口配置必须绝对精确。配置接口时&#xff0c;我们需要指定网络层地址、介质类型和带宽,还需使用其他管理命令。…

mysql数据去重语句_数据库 mysql 语句

LAMP: Linux系统 A阿帕奇服务器 Mysql数据库 Php语言mysql:常用代码create table CeShi1(Uid varchar(50) primary key,Pwd varchar(50),Name varchar(50),Nation varchar(50),foreign key(Nation) references Nation(Code))写查询语句需要注意&#xff1a;1.创建表的时候&…

mysql中utf8_bin、utf8_general_ci、utf8_general_cs编码区别

转载地址: https://www.cnblogs.com/exmyth/p/3616672.html在mysql中存在着各种utf8编码格式&#xff0c;如下表&#xff1a;1&#xff09;utf8_bin2&#xff09;utf8_general_ci3&#xff09;utf8_general_csutf8_bin将字符串中的每一个字符用二进制数据存储&#xff0c;区分大…

利用闭包实现多次ajax请求只执行最后一次

点一个按钮&#xff0c;则向服务器请求资源&#xff0c;不作处理时&#xff0c;多次点击后会有很多个请求在等待。我们知道一般我们用ajax是异步请求&#xff0c;那么我们快速重复点击一个按钮得到的结果其实我们并不知道是哪次点击的结果可能是第一次可能是最后一次也可能是第…

3dmax批量导出fbx_推荐一款超实用的3DMAX插件——模法师

模法师集成于3DMAX上&#xff0c;到老子云平台下载插件后&#xff0c;直接双击运行安装就能使用了。有多好用呢&#xff1f;好比游戏开了挂&#xff0c;效率瞬间翻几番。主要提供三大功能&#xff1a;1、批量格式转换简单地说&#xff0c;你可以把大量模型文件&#xff0c;同时…

python实现平衡二叉树_LeetCode 110. 平衡二叉树 | Python

# 110. 平衡二叉树---题目来源&#xff1a;力扣(LeetCode)[https://leetcode-cn.com/problems/balanced-binary-tree](https://leetcode-cn.com/problems/balanced-binary-tree)## 题目---给定一个二叉树&#xff0c;判断它是否是高度平衡的二叉树。本题中&#xff0c;一棵高度…

「欧拉定理」学习笔记(费马小定理)

欧拉定理&#xff1a;对于互质的两个正整数$a, n$&#xff0c;满足$a^{φ(n)} ≡ 1\ (mod\ n)$ 证明&#xff1a; 设集合$S$包含所有$n$以内与$n$互质的数&#xff0c;共有$φ(n)$个&#xff1a;$$S \{ x_1, x_2, ..., x_{φ(n)} \} $$ 再设集合$T$&#xff1a;$$T \{ a * x…

Python将MySQL表数据写入excel

背景&#xff1a;将mysql表查询结果写入excel。 1.使用sqlyog工具将查询结果导出到Excel.xml中&#xff0c;用excel打开发现&#xff1a;因为text字段中有回车换行操作&#xff0c;显示结果行是乱的。 2.用mysql -uadmin -p -h -P -NBe"select * from tb;" >>a…

nacos动态配置数据源_Jasper 怎么配置动态数据源

Jasper 本身是不支持动态数据源的&#xff0c;能用的解决方式是通过 api 自定义数据源&#xff0c;实际操作就是根据条件判断后动态设定 jdbc 的 url、用户名及密码等连接属性。比如&#xff1a;String userName userDetails.getUsername();// obtain a connection based on t…

Linux命令之top

top –hv | -abcHimMsS –d delay –n iterations –p pid [, pid …] top程序提供运行系统的动态实时视图&#xff0c;它可以显示系统概要信息以及当前由Linux内核当前管理的任务列表。所示的系统概要信息的类型以及为任务显示的信息的类型、顺序和大小都是用户可配置的&#…

seal report mysql_Seal Report开放数据库报表工具(.Net)

概述&#xff1a;开放数据库报表工具(.Net)简介&#xff1a;Seal-Report提供了一个完整的框架&#xff0c;用于从任何数据库生成日常报告和仪表板。Seal-Report是Microsoft .NET Framework完全用C&#xff03;编写的开源工具。Seal Report算是报表工具中比较好用的一个&#xf…

注册亚马逊云服务

要英文填写还要字符限制&#xff0c;好严格 转载于:https://www.cnblogs.com/ZHONGZHENHUA/p/6249805.html

行波iq调制器_高速InP基半导体电光调制器行波电极结构研究

【1】Winzer P J, Essiambre R J. Advanced modulation formats for high-capacity optical transport networks[J].Lightwave Technol., 2006, 24(12):4711-4728.【2】Dagli N.High-speed photonics device[M]. Taylor & Francis, 2007.【3】Zhang L,Sinsky J, Thourhout …

PIXI 下落文字消除(3)

图片示例&#xff0c;简陋的图&#xff0c;记录下落过程&#xff0c; 1、创建应用实例并添加到DOM元素上。 &#xff08;会看到一个黑色画布&#xff0c;没有任何元素&#xff0c;接下来会在画布上创建文字&#xff09; 2、创建 TextStyle 用来设置要显示字体样式 3、随机产生…

python魔术方法call_php魔术方法__call

__call是魔术方法中的一个&#xff0c;当程序调用到当前类中未声明或没权限调用的方法时&#xff0c;就会调用__call方法class test{public function emptyFunc(){$getArgs func_get_args();$funcName $getArgs[0];//$params array_slice($getArgs, 1);//var_dump($params);…

app启动时间命令

app启动&#xff1a; 冷启动和热启动 冷启动方式&#xff1a; adb shell am start -W -n package/activity 停止app命令&#xff1a; adb shell am force-stop package 热启动命令和冷启动命令一样 停止命令&#xff1a; adb shell input keyevent 3 查看package/activity命令&…

华为手机媒体音量自动静音_华为手机的音量键还可以这么用,涨见识!

身边很多朋友都是用的是华为手机&#xff0c;我就纳闷了&#xff0c;华为手机真的有那么好用吗&#xff1f;听朋友跟我细细说了一番&#xff0c;我被说动了&#xff0c;准备也去换一个华为手机&#xff0c;就冲它的音量键有那多妙用&#xff0c;我也不能错过一款华为手机&#…

Mui.ajax请求服务器正确返回json数据格式

ajax&#xff1a; mui.ajax(http://server-name/login.php,{data:{username:username,password:password},dataType:json,//服务器返回json格式数据type:post,//HTTP请求类型timeout:10000,//超时时间设置为10秒&#xff1b;success:function(data){//服务器返回响应&#xff0…

day1作业(格式化输出)

练习&#xff1a;用户输入姓名、年龄、工作、爱好 &#xff0c;然后打印成以下格式------------ info of Egon -----------Name : EgonAge : 22Sex : maleJob : Teacher ------------- end -----------------完成情况&#xff1a;in_nameinput(请输入您的姓名&#xff1…

rust 官服指令_RUST 命令大全(包括服务器指令)

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼RUST MOD(以下在聊天框内输入)基本命令/share playername 【shares your doors with a player(共享你的门给一个玩家)】/unshare playername 【unshares your doors with a player(解除对一个玩家的门共享)】/help 【Shows command…

postgresql存图片字段类型_PostgreSQL 入门 | Linux 中国

安装、设置、创建和开始使用 PostgreSQL 数据库。-- Greg Pittman每个人或许都有需要在数据库中保存的东西。即使你执着于使用纸质文件或电子文件&#xff0c;它们也会变得很麻烦。纸质文档可能会丢失或混乱&#xff0c;你需要访问的电子信息可能会隐藏在段落和页面的深处。在我…

关于ES6中Promise的应用-顺序合并Promise,并将返回结果以数组的形式输出

1.Promise 基础知识梳理 创建一个Promise实例 const promise new Promise(function(resolve, reject) {if (success){resolve(value);} else {reject(error);} }); Promise构造函数接受一个函数作为参数&#xff0c;该函数的两个参数分别是resolve和reject。它们是两个函数&am…

Java计算两个字符串日期之间的天数差

Java计算两个字符串日期之间的天数差 调用方法&#xff1a; public static void main(String[] args) throws ParseException {String a "2017-12-01"; // 时间字符串String b "2017-12-31";Long between_dayInteger between_days(a, b);System.out.pri…

java file_Java IO: File

原文链接 作者: Jakob Jenkov 译者: 李璟(jlee381344197gmail.com)Java IO API中的FIle类可以让你访问底层文件系统&#xff0c;通过File类&#xff0c;你可以做到以下几点&#xff1a;检测文件是否存在读取文件长度重命名或移动文件删除文件检测某个路径是文件还是目录读取目录…

数学建模优化模型简单例题_数学建模之优化模型:存储模型

点击上方「蓝字」关注我们最近&#xff0c;为申报市级精品课程&#xff0c;我为我校“数学建模与科学计算”课程录制了讲课视频&#xff0c;下面是3.1节优化模型的第一个例子&#xff1a;存储模型。敬请大家批评指正&#xff01;优化模型是数学建模里比较简单、但也非常常用的建…

shiro异常类型

<!-- 身份认证异常 --> <!-- 身份令牌异常&#xff0c;不支持的身份令牌 --> org.apache.shiro.authc.pam.UnsupportedTokenException <!-- 未知账户/没找到帐号,登录失败 --> org.apache.shiro.authc.UnknownAccountException <!-- 帐号锁定 --&…

生产环境下Centos 6.5优化配置 (装载)

本文 centos 6.5 优化 的项有18处: 1、centos6.5最小化安装后启动网卡 2、ifconfig查询IP进行SSH链接 3、更新系统源并且升级系统 4、系统时间更新和设定定时任 5、修改ip地址、网关、主机名、DNS 6、关闭selinux&#xff0c;清空iptables 7、创建普通用户并进行sudo授权管理 8…

java this final_Java this、final等关键字总结

this关键字this引用对象自身。它也可以在构造方法内部用于调用同一个类的其他构造方法。隐藏的静态变量可以通过”类.静态变量”来引用&#xff0c;而隐藏的实例变量就需要使用”this.实例变量”来引用。调用一个重载的构造方法this引用是必须的。this是个隐式参数&#xff0c;…

档案盒正面标签制作_2020昆明大学档案盒价格价格行情

2020昆明大学档案盒价格价格行情背景技术档案盒是企业、单位部门或财务部门整理和装订储存文件的不可缺少的办公用具&#xff0c;主要是对档案材料、财务凭证等进行收集、查找等。目前需要查找档案时需要将所有的档案材料取出&#xff0c;然后一一查找&#xff0c;工作效率低&a…