SKYLINE UVALive - 4108

我一开始没有想到用线段树,是我学得太僵了...

我们要记录每段的最大高度,而且要组织成区间信息,这要用到线段树

 

怎么用呢?

线段树维护区间最大值;对于每个线段,先二分至其包含区间,如果最大值>=h,就能把这个区间赋值

优化:如果最小值<=h,即可返回

 

这道题算是一个线段树的小魔改吧...

我们发现:对于线段树,查询和修改两个操作是可以合在一起的;找区间也不是固定的,可以根据区间信息,二分至我们目标的区间

#include<iostream>
#include<cstdio>
#include<cstring>using namespace std;const int N=1e5+3,V=1e5+3;struct line{int l,r,h;
}a[N];struct sgt{int mn,mx;int st;
}R[V<<2];int gl;
void push_down(int o,int l,int r){if(R[o].st){R[o<<1].mx=R[o<<1|1].mx=R[o<<1].mn=R[o<<1|1].mn=R[o].st;R[o<<1].st=R[o<<1|1].st=R[o].st;R[o].st=0;}
}
void push_up(int o,int l,int r){R[o].mx=max(R[o<<1].mx,R[o<<1|1].mx);R[o].mn=min(R[o<<1].mn,R[o<<1|1].mn);
}
int modify(int o,int l,int r)
{if(a[gl].l<=l&&a[gl].r>=r){if(R[o].mx<=a[gl].h){R[o].mx=R[o].mn=a[gl].h;R[o].st=a[gl].h;return r-l+1;}else if(R[o].mn>a[gl].h)return 0;            }push_down(o,l,r);int mid=(l+r)>>1,ret=0;if(a[gl].l<=mid)ret+=modify(o<<1,l,mid);if(a[gl].r>mid)ret+=modify(o<<1|1,mid+1,r);push_up(o,l,r);return ret;
}int main()
{int T;scanf("%d",&T);while(T--){int n;scanf("%d",&n);int bd=0;for(int i=1;i<=n;i++)scanf("%d%d%d",&a[i].l,&a[i].r,&a[i].h),a[i].r--,bd=max(bd,a[i].r);int ans=0;memset(R,0,sizeof R);for(int i=1;i<=n;i++){gl=i;ans+=modify(1,1,bd);}printf("%d\n",ans);}return 0;
}

 

转载于:https://www.cnblogs.com/mgnfcnt/p/9464389.html

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

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

相关文章

Mybatis源码学习笔记

Mybatis核心概念: Configuration : 管理 mysql-config.xml 全局配置关系类 SqlSessionFactory: Session 管理工厂接口 Session: SqlSession 是一个面向用户&#xff08;程序员&#xff09;的接口。SqlSession 中提供了很多操作数据库的方法 Executor : 执行器是一个接口…

[css] 你用过css的tab-size属性吗?浏览器默认显示tab为几个空格?

[css] 你用过css的tab-size属性吗&#xff1f;浏览器默认显示tab为几个空格&#xff1f; tab-size 属性规定制表符&#xff08;tab&#xff09;字符的空格长度。在 HTML 中&#xff0c;制表符&#xff08;tab&#xff09;字符通常显示为一个单一的空格字符个人简介 我是歌谣&…

JQData数据提取及MySQL简单操作——基于Python

JQData平台真的挺不错&#xff0c;平台数据可以免费使用一年&#xff0c;满足绝大多数人需求&#xff0c;具体账号获取请自行百度哟~ 因需要高频数据而Wind也只给近三年&#xff0c;再要还得购&#xff0c;&#xff0c;机缘遇到这一平台&#xff0c;获得了账号试用很不错&#…

数据库事物相关笔记

一、数据库的事物的基本特性 事物是区分文件存储系统与Nosql数据库重要特性之一&#xff0c;其存在的意义是为了保证即使在并发情况下也能正确的执行crud操作。怎样才算是正确的呢&#xff1f;这时提出了事物需要保证的四个特性即ACID&#xff1a; A: 原子性(atomicity) 事物…

[css] clear属性只对块级元素有效么?为何无法应用于行内元素?

[css] clear属性只对块级元素有效么&#xff1f;为何无法应用于行内元素&#xff1f; block元素浮动之后已经脱离了文档流了&#xff0c;排列的顺序都不一样了&#xff0c;所以清除了之后有效果。 inline-block还是在文档流里面&#xff0c;加浮动不加浮动都没有什么作用的&am…

GO语言-基础语法:条件判断

1. IF判断(aa.txt内容&#xff1a;asdfgh。bb.txt内容&#xff1a;12345) package mainimport ("io/ioutil""fmt" )func main() {const filename1, filename2 "aa.txt", "bb.txt"contents, err : ioutil.ReadFile(filename1) if err …

JVM模型学习笔记

JVM由三个主要的子系统构成 1. 运行时数据区&#xff08;内存结构&#xff09;: 运行时数据区也是JVM的核心部分 内存数据区又分&#xff1a;堆、java栈、本地方法栈、程序计数器、方法区 1.1 本地方法栈(线程私有)&#xff1a; 登记native方法&#xff0c;在Execution Eng…

[css] css的负边距有哪些应用场景?

[css] css的负边距有哪些应用场景&#xff1f; 垂直水平居中 通过伪元素扩大元素覆盖范围个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题

tomcat 设置虚拟路径的4种方法

通常使用方法1或者方法2 方法1 &#xff08;添加配置文件&#xff09;&#xff1a;推荐使用&#xff0c;不需要重启服务器 在Tomcat根目录下的/conf/Catalina/localhost/ 路径下新建一个filename.xml&#xff0c;并在该xml中编写语句 即可创建虚拟站点&#xff0c;虚拟站点名为…

sharding-sphere按月动态分表

公司有个记录表&#xff0c;每天有几百万的数据&#xff0c;所以我决定按月把他分下表。 用spring整合的。 首先&#xff0c;sharding-sphere不支持自动创建表&#xff0c;所以我提前创建了两年的表&#xff0c;命名规则 logicTableName _2019_06 以下是官方文档上面的分片…

[css] 你了解CSS Houdini吗?说说它的运用场景有哪些?

[css] 你了解CSS Houdini吗&#xff1f;说说它的运用场景有哪些&#xff1f; Houdini是一组底层API&#xff0c;它们公开了CSS引擎的各个部分&#xff0c;从而使开发人员能够通过加入浏览器渲染引擎的样式和布局过程来扩展CSS。 Houdini是一组API&#xff0c;它们使开发人员可…

python 入门学习

把sublime编辑的.py文件保存在本地&#xff0c;在当前目录下输入 1 python hello.py 即可运行该程序&#xff0c;一定要在当前目录下运行。如果当前目录下没有该文件则不能成功运行。 其中cmd黑窗口下有这么几个快捷键&#xff0c; c: 进入另一个盘 dir 显示当前目录 tab 进…

[css] 列举一些你认为最“昂贵”的css属性并解释为什么

[css] 表列举一些你认为最“昂贵”的css属性并解释为什么 filter 吧&#xff0c;学过高斯模糊算法的表示头疼个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题

大厂Java岗面试心得记录

最近裸辞&#xff0c;面了几家大厂&#xff0c;offer率高达100% 哈哈&#xff0c;然后发现选公司也是一件难事。 废话不多说&#xff0c;分享一下&#xff0c;我遇到的面试题&#xff0c;大概有以下这些&#xff1a; JVM: 1.JVM有哪些区域&#xff1f; 2.堆和栈分别说说内部东…

原生Js 两种方法实现页面关键字高亮显示

方法一 依靠正则表达式修改 1.获取obj的html 2.统一替换html标签 3.替换要修改的关键字 4.再把html标签修改回去 不足就是如果查找的关键字跟替换的标签一样就有冲突了 <!DOCTYPE HTML> <html lang"en"> <meta http-equiv"Content-Type" co…

[css] 为什么说css的选择器是从右向左匹配?

[css] 为什么说css的选择器是从右向左匹配&#xff1f; 从右往左匹配会首先排除很多错误的匹配&#xff0c;打个简单的比方&#xff0c;孩子只有一个父亲&#xff0c;但是父亲可以有很多个孩子&#xff0c;从孩子找父亲简单&#xff0c;从父亲找某个指定的孩子可能就会找到错误…

SpringBoot启动报错java.nio.charset.MalformedInputException: Input length = 2解决方案

最近新搭的一个项目&#xff0c;启动时&#xff0c;会报MalformedInputException这个异常&#xff0c; 百度了很久&#xff0c;网上说的千篇一律&#xff0c; 有的说&#xff0c;把yml复制到txt再复制回来 有的说&#xff0c;设置eclipse的utf-8环境 这些根本没有根治这个问…

IDEA主题设置与eclipse代码风格一致

习惯了用eclipse的你&#xff0c;是不是转到用idea特别不习惯&#xff0c;没有关系&#xff0c; 我们可以把idea的代码风格改成eclipse的&#xff0c;快捷键也换成eclipse的。 下载这个jar包&#xff0c;导入settings文件即可 下载地址 : https://download.csdn.net/download…

bash shell 中时间操作常用方法总结

在日常的工作中&#xff0c;bash shell 的时间操作非常频繁。比如shell脚本定时发送数据统计的时候&#xff0c;会查看当前是否为预定的发送时间。或者使用文件保存一些数据时&#xff0c;一般会生成时间字符串当做文件名的一部分。总结一下&#xff0c;以后再用到就不用上网到…

[css] 使用css实现一个loading的效果

[css] 使用css实现一个loading的效果 <div class"donut"></div> Keyframes donut-spin {0% {transform: rotate(0deg);}100% {transform: rotate(360deg);} }.donut {display: inline-block;border: 4px solid rgba(0, 0, 0, 0.1);border-left-color: #…