CF1080F Katya and Segments Sets

题目链接:洛谷

题目描述:【看翻译】


这种强制在线的方法可真是奇妙。

主席树可真是奇妙。

我们用主席树的版本维护$x\leq l$的限制,用线段树维护$[a,b]$的限制,用节点的值来维护$r\leq y$的限制。

详细地说,就是先将线段排序($l$为第一关键字,$r$为第二关键字),然后倒序所属集合作为位置,右端点作为值插入主席树。

主席树的第$i$个版本维护的是排序后,后面$k-i+1$个线段的线段树。

因为它要求集合里面有一个满足就可以,所以同一个位置的右端点取最小值

因为它要求$[a,b]$的集合都要满足,所以线段树维护区间最大值

每次查询的时候,找到左端点$\geq x$的最靠前的线段,设为第$i$个,则在第$i$个版本中,看$[a,b]$的最大值是否$\leq y$,如果是就是yes,否则就是no。

 1 #include<bits/stdc++.h>
 2 #define Rint register int
 3 using namespace std;
 4 const int N = 300003, INF = 0x3f3f3f3f;
 5 struct Seg {
 6     int l, r, p;
 7     inline bool operator < (const Seg &o) const {return l < o.l || l == o.l && r < o.r;}
 8 } a[N];
 9 int n, m, k, cnt, root[N], seg[N << 5], ls[N << 5], rs[N << 5];
10 inline void pushup(int x){
11     seg[x] = max(seg[ls[x]], seg[rs[x]]);
12 }
13 inline void build(int &x, int L, int R){
14     seg[x = ++ cnt] = INF;
15     if(L == R) return;
16     int mid = L + R >> 1;
17     build(ls[x], L, mid);
18     build(rs[x], mid + 1, R);
19 }
20 inline void change(int &nx, int ox, int L, int R, int pos, int val){
21     seg[nx = ++ cnt] = seg[ox];
22     ls[nx] = ls[ox]; rs[nx] = rs[ox];
23     if(L == R){
24         seg[nx] = min(seg[nx], val);
25         return;
26     }
27     int mid = L + R >> 1;
28     if(pos <= mid) change(ls[nx], ls[ox], L, mid, pos, val);
29     else change(rs[nx], rs[ox], mid + 1, R, pos, val);
30     pushup(nx);
31 }
32 inline int query(int x, int L, int R, int l, int r){
33     if(l <= L && R <= r) return seg[x];
34     int mid = L + R >> 1, ans = 0;
35     if(l <= mid) ans = max(ans, query(ls[x], L, mid, l, r));
36     if(mid < r) ans = max(ans, query(rs[x], mid + 1, R, l, r));
37     return ans;
38 }
39 int main(){
40     scanf("%d%d%d", &n, &m, &k);
41     for(Rint i = 1;i <= k;i ++)
42         scanf("%d%d%d", &a[i].l, &a[i].r, &a[i].p);
43     sort(a + 1, a + k + 1);
44     build(root[k + 1], 1, n);
45     for(Rint i = k;i;i --)
46         change(root[i], root[i + 1], 1, n, a[i].p, a[i].r);
47     a[k + 1].l = INF; 
48     while(m --){
49         int A, B, X, Y;
50         scanf("%d%d%d%d", &A, &B, &X, &Y);
51         int ans = -1, mid, left = 1, right = k + 1;
52         while(left <= right){
53             mid = left + right >> 1;
54             if(a[mid].l >= X) ans = mid, right = mid - 1;
55             else left = mid + 1;
56         }
57         puts(query(root[ans], 1, n, A, B) <= Y ? "yes" : "no");
58         fflush(stdout);
59     }
60 }
View Code

 

转载于:https://www.cnblogs.com/AThousandMoons/p/ntfakgdoi.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/364970.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在微信小程序上,帮助中心界面实现类似手风琴案例

小程序wxml代码如下: <block wx:for"{{arrdata}}" wx:key""><view class"centent_title" tap"open_that" data-index"{{index}}"><view class"title" >{{item.name}}?</view><image…

python 等待其他线程执行完_面试官:如何让线程顺序执行,join,还有其他办法吗?...

面试官&#xff1a;如让线程顺序执行&#xff1f;我&#xff1a;使用Thread的join方法。面试官&#xff1a;除了join还有别的办法吗&#xff1f;我&#xff1a;目前只用过join。面试官&#xff1a;哦&#xff0c;那你了解CountDownLatch吗&#xff1f;我&#xff1a;不了解&…

计算斐波那契数列

O(n)复杂度方法O(logn)复杂度方法计算矩阵的n次方&#xff0c;可以先求矩阵的n/2次方&#xff0c;然后再平方即可。 1 #include <cassert>2 3 struct Matrix2By24 {5 Matrix2By26 (7 long long m00 0,8 long long m01 0,9 long long m…

使用ANTLR4,用于代码镜像和基于Web的DSL的Primefaces扩展

DSL是很酷的东西&#xff0c;但是我不清楚它们有什么用。 然后我意识到它们对以下方面有好处&#xff1a; 摆脱复杂的UI 意思是 更快的做事方式 而已。 当我阅读此博客时&#xff0c;我得出了这个结论。 如果您的用户是技术人员&#xff0c;并且不惧怕类似SQL的语法处理方…

hdu 1069 Monkey and Banana 【动态规划】

题目 题意&#xff1a;研究人员要测试猴子的IQ&#xff0c;将香蕉挂到一定高度&#xff0c;给猴子一些不同大小的箱子&#xff0c;箱子数量不限&#xff0c;让猩猩通过叠长方体来够到香蕉。 现在给你N种长方体&#xff0c; 要求&#xff1a;位于上面的长方体的长和宽 要小于 …

使用带有OAuth2的Web应用程序和使用JWT来调用API – WSO2 API Manager

在这篇文章中&#xff0c;我将分享我在WSO2 API管理器&#xff08;API-M&#xff09;方面的经验和理解&#xff0c;以解决该行业中非常普遍和有用的情况。 简要地说明以下流程。 公开了一个API&#xff0c;供应用程序开发人员在API Manager&#xff08;可为API添加访问控制&a…

scala的插值器

Scala 为我们提供了三种字符串插值的方式&#xff0c;分别是 s, f 和 raw。它们都是定义在 StringContext 中的方法。 s 字符串插值器 val a 2println(s"小明今年$a 岁了") f 字符串插值器 它除 s 的功能外(不指定格式就和 s 一样)&#xff0c;还能进行格式化输出&a…

confluence 编辑器加载_Onlyoffice集成Confluence的工作原理

onlyoffice 与 confluence集成使用&#xff0c;使用onlyoffice connector for confluence 插件对接confluence插件在confluence中创建了一个新的按钮动作&#xff0c;Edit in OnlyOffice 用来处理office文档。这允许多用户实时协作并且将变更返回到confluence中。具体工作原理&…

红帽JBoss BRMS和BPMS富客户端框架展示了与GWT / Errai / UberFire和AngularJS的多语言集成...

上周&#xff0c;我发布了一个博客&#xff0c;重点介绍了我的演示文稿&#xff0c;该演示文稿展示了我们在BRMS和BPMS平台内完成的工作&#xff0c;Drools和jBPM项目的产品化版本所产生的丰富客户端平台。 该演示文稿是所有屏幕截图和视频&#xff0c;您可以在此处找到博客和幻…

vscode如何设置回车自动换行缩进?

要解决这个问题&#xff0c;首先打开设置&#xff0c;查找tabsize&#xff0c;进入settings.json。 把"editor.autoIndent"的属性值改为false&#xff0c;即"editor.autoIndent": "false"&#xff0c;就可以了。

vue 过滤器使用的传参说明

在table中&#xff0c;需要对obj的数据类型进行文字转换&#xff0c;例如后台接口返回的姓别值&#xff1a;1&#xff0c;2。其中需要页面根据字典需要把1》男&#xff0c;2》女进行转换。 以前的习惯是每一个过滤方法都写一个方法进行转换&#xff0c;例如&#xff1a; 页面代…

ruby sinatra mysql_一分钟开始持续集成之旅系列之:Ruby + Sinatra 应用

前言现代软件工程越来越复杂&#xff0c;而开发效率随着软件复杂度增加呈指数型下降。为在提高开发效率的同时也能保证质量&#xff0c;越来越多团队开始践行敏捷开发方法。持续集成是敏捷开发的重要实践之一。它倡导团队通过自动化构建工具频繁地验证软件可用性&#xff0c;从…

C++语言实现-邻接表

图的邻接表实现 邻接表是图的一种链式存储结构。主要是应对于邻接矩阵在顶点多边少的时候&#xff0c;浪费空间的问题。它的方法就是声明两个结构。如下图所示&#xff1a; 先来看看伪代码&#xff1a; typedef char Vertextype; //表结点结构 struct ArcNode { int adjvex; …

使用Lucene的新FreeTextSuggester查找长尾建议

Lucene的“ 建议”模块提供了许多有趣的自动建议实现&#xff0c;以便在用户将每个字符输入搜索框时为他们提供实时搜索建议。 例如&#xff0c; WFSTCompletionLookup将所有建议及其权重编译到一个紧凑的有限状态传感器中 &#xff0c;从而可以对基本建议进行快速前缀查找。 …

mysql 查看锁表日志_MYSQL 表锁情况查看

查看锁表情况mysql> show status like ‘Table%’;—————————-——–| Variable_name | Value |—————————-——–| Table_locks_immediate | 795505 || Table_locks_waited | 0 || Table_open_cache_hits | 0 || Table_open_cache_misses | 0 || Table_ope…

Java,Scala,Guava和Trove集合-它们可以容纳多少数据?

关于我们的数据结构&#xff0c;令人着迷的事情之一是&#xff0c;即使我们对它们非常熟悉&#xff0c;我们仍然很难说出像HashMap这样基本的东西在1GB的内存中可以容纳多少个项目。 我们可能会在学校&#xff0c;高级开发人员那里学到这一点&#xff0c;或者由于数据结构选择不…

switch 失效

switch 开关失效无法切换&#xff0c;可以关闭&#xff0c;无法开启。 发现问题点 require-table.js 中toggle value的数据类型不是 number 导致 &#xff08;value ? no : yes )判断总为no&#xff1b; 前面将value 强制转换为number类型即可 转载于:https://www.cnblogs.c…

纯php socket mysql_PHP 连接 unix_socket MySQL

当MySQL使用Unix Socket启动时&#xff0c;直接使用localhost会发生了一个数据库错误&#xff0c;发生无法连接数据库错误。 Warning: mysql_connect() [function.mysql-connect]: [2002] 这时应当修改hostname&#xff0c;例如在CI 配置数据库 (database.php) 从&#xff1a; …

mysql为什么不能插入数据_mysql为啥不能插入数据

mysql为何不能插入数据&#xff1f;安装AppServ后首次使用mysql&#xff0c;没有图形界面&#xff0c;在“MySql Command Line Client”的操作如下&#xff1a;mysql> create database cars;Query OK, 1 row affected (0.00 sec)mysql> use cars;Database changedmysql&g…

mocha 测试 mysql_e2e 自动化集成测试 架构 实例 WebStorm Node.js Mocha WebDrive

e2e 自动化集成测试 架构 京东 商品搜索 实例 WebStorm Node.js Mocha WebDriverIO Selenium Step by step 二 图片验证码的识别 &#xff0c; 下面讲一下Node.js中如何访问数据库&#xff0c; 在做自动化测试过程中&#xff0c; 经常可能遇到需要到数据库取值&#xff0c;或是…